% July 1992 %
% %
% %
-% Copyright 1999-2010 ImageMagick Studio LLC, a non-profit organization %
+% Copyright 1999-2011 ImageMagick Studio LLC, a non-profit organization %
% dedicated to making software imaging solutions freely available. %
% %
% You may not use this file except in compliance with the License. You may %
%
% o exception: return any errors or warnings in this structure.
%
-%
*/
static Image *ReadUYVYImage(const ImageInfo *image_info,
ExceptionInfo *exception)
Image
*image;
- long
- y;
-
MagickBooleanType
status;
- register long
+ register ssize_t
x;
register PixelPacket
*q;
- register long
- i;
+ ssize_t
+ y;
unsigned char
u,
status=OpenBlob(image_info,image,ReadBinaryBlobMode,exception);
if (status == MagickFalse)
return((Image *) NULL);
- for (i=0; i < image->offset; i++)
- if (ReadBlobByte(image) == EOF)
- {
- ThrowFileException(exception,CorruptImageError,"UnexpectedEndOfFile",
- image->filename);
- break;
- }
+ if (DiscardBlobBytes(image,image->offset) == MagickFalse)
+ ThrowFileException(exception,CorruptImageError,"UnexpectedEndOfFile",
+ image->filename);
image->depth=8;
if (image_info->ping != MagickFalse)
{
/*
Accumulate UYVY, then unpack into two pixels.
*/
- for (y=0; y < (long) image->rows; y++)
+ for (y=0; y < (ssize_t) image->rows; y++)
{
q=QueueAuthenticPixels(image,0,y,image->columns,1,exception);
if (q == (PixelPacket *) NULL)
break;
- for (x=0; x < (long) (image->columns >> 1); x++)
+ for (x=0; x < (ssize_t) (image->columns >> 1); x++)
{
u=(unsigned char) ReadBlobByte(image);
y1=(unsigned char) ReadBlobByte(image);
v=(unsigned char) ReadBlobByte(image);
y2=(unsigned char) ReadBlobByte(image);
- q->red=ScaleCharToQuantum(y1);
- q->green=ScaleCharToQuantum(u);
- q->blue=ScaleCharToQuantum(v);
+ SetRedPixelComponent(q,ScaleCharToQuantum(y1));
+ SetGreenPixelComponent(q,ScaleCharToQuantum(u));
+ SetBluePixelComponent(q,ScaleCharToQuantum(v));
q++;
- q->red=ScaleCharToQuantum(y2);
- q->green=ScaleCharToQuantum(u);
- q->blue=ScaleCharToQuantum(v);
+ SetRedPixelComponent(q,ScaleCharToQuantum(y2));
+ SetGreenPixelComponent(q,ScaleCharToQuantum(u));
+ SetBluePixelComponent(q,ScaleCharToQuantum(v));
q++;
}
if (SyncAuthenticPixels(image,exception) == MagickFalse)
break;
- status=SetImageProgress(image,LoadImageTag,y,image->rows);
+ status=SetImageProgress(image,LoadImageTag,(MagickOffsetType) y,
+ image->rows);
if (status == MagickFalse)
break;
}
%
% The format of the RegisterUYVYImage method is:
%
-% unsigned long RegisterUYVYImage(void)
+% size_t RegisterUYVYImage(void)
%
*/
-ModuleExport unsigned long RegisterUYVYImage(void)
+ModuleExport size_t RegisterUYVYImage(void)
{
MagickInfo
*entry;
Image
*uyvy_image;
- long
- y;
-
MagickBooleanType
full,
status;
register const PixelPacket
*p;
- register long
+ register ssize_t
x;
+ ssize_t
+ y;
+
/*
Open output image file.
*/
(void) TransformImageColorspace(uyvy_image,YCbCrColorspace);
full=MagickFalse;
(void) ResetMagickMemory(&pixel,0,sizeof(MagickPixelPacket));
- for (y=0; y < (long) image->rows; y++)
+ for (y=0; y < (ssize_t) image->rows; y++)
{
p=GetVirtualPixels(uyvy_image,0,y,image->columns,1,&image->exception);
if (p == (const PixelPacket *) NULL)
break;
- for (x=0; x < (long) image->columns; x++)
+ for (x=0; x < (ssize_t) image->columns; x++)
{
if (full != MagickFalse)
{
- pixel.green=(pixel.green+GetGreenSample(p))/2;
- pixel.blue=(pixel.blue+GetBlueSample(p))/2;
+ pixel.green=(pixel.green+GetGreenPixelComponent(p))/2;
+ pixel.blue=(pixel.blue+GetBluePixelComponent(p))/2;
(void) WriteBlobByte(image,ScaleQuantumToChar((Quantum) pixel.green));
(void) WriteBlobByte(image,ScaleQuantumToChar((Quantum) pixel.red));
(void) WriteBlobByte(image,ScaleQuantumToChar((Quantum) pixel.blue));
- (void) WriteBlobByte(image,ScaleQuantumToChar(GetRedSample(p)));
+ (void) WriteBlobByte(image,ScaleQuantumToChar(
+ GetRedPixelComponent(p)));
}
- pixel.red=(double) GetRedSample(p);
- pixel.green=(double) GetGreenSample(p);
- pixel.blue=(double) GetBlueSample(p);
+ pixel.red=(double) GetRedPixelComponent(p);
+ pixel.green=(double) GetGreenPixelComponent(p);
+ pixel.blue=(double) GetBluePixelComponent(p);
full=full == MagickFalse ? MagickTrue : MagickFalse;
p++;
}
- status=SetImageProgress(image,LoadImageTag,y,image->rows);
+ status=SetImageProgress(image,LoadImageTag,(MagickOffsetType) y,
+ image->rows);
if (status == MagickFalse)
break;
}