summaryrefslogtreecommitdiff
path: root/src/libxinevdec/image.c
diff options
context:
space:
mode:
authorPetri Hintukainen <phintuka@users.sourceforge.net>2012-06-15 10:25:46 +0300
committerPetri Hintukainen <phintuka@users.sourceforge.net>2012-06-15 10:25:46 +0300
commit6eca0da170fd8d83bb3b611ea579b27a7c84b12a (patch)
treedbf0f05630678cad2c6c53aad7733eea5c2f53e0 /src/libxinevdec/image.c
parent52732e443424511ffc285b009f999cf00fbfa090 (diff)
downloadxine-lib-6eca0da170fd8d83bb3b611ea579b27a7c84b12a.tar.gz
xine-lib-6eca0da170fd8d83bb3b611ea579b27a7c84b12a.tar.bz2
image decoders: crop image if allocated frame is smaller than requested
Diffstat (limited to 'src/libxinevdec/image.c')
-rw-r--r--src/libxinevdec/image.c20
1 files changed, 15 insertions, 5 deletions
diff --git a/src/libxinevdec/image.c b/src/libxinevdec/image.c
index b63cfa265..4a872655e 100644
--- a/src/libxinevdec/image.c
+++ b/src/libxinevdec/image.c
@@ -153,6 +153,20 @@ static void image_decode_data (video_decoder_t *this_gen, buf_element_t *buf) {
lprintf("image loaded successfully\n");
/*
+ * alloc video frame and set cropping
+ */
+ img = this->stream->video_out->get_frame (this->stream->video_out, width, height,
+ (double)width / (double)height,
+ XINE_IMGFMT_YUY2,
+ VO_BOTH_FIELDS);
+
+ if (width > img->width)
+ width = img->width;
+ if (height > img->height)
+ height = img->height;
+ img->ratio = (double)width / (double)height;
+
+ /*
* rgb data -> yuv_planes
*/
width &= ~1; /* must be even for init_yuv_planes */
@@ -176,12 +190,8 @@ static void image_decode_data (video_decoder_t *this_gen, buf_element_t *buf) {
free(img_buf);
/*
- * alloc and draw video frame
+ * draw video frame
*/
- img = this->stream->video_out->get_frame (this->stream->video_out, width,
- height, (double)width/(double)height,
- XINE_IMGFMT_YUY2,
- VO_BOTH_FIELDS);
img->pts = buf->pts;
img->duration = 3600;
img->bad_frame = 0;