2 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
6 % SSSSS TTTTT RRRR EEEEE AAA M M %
7 % SS T R R E A A MM MM %
8 % SSS T RRRR EEE AAAAA M M M %
10 % SSSSS T R R EEEEE A A M M %
13 % MagickCore Pixel Stream Methods %
20 % Copyright 1999-2012 ImageMagick Studio LLC, a non-profit organization %
21 % dedicated to making software imaging solutions freely available. %
23 % You may not use this file except in compliance with the License. You may %
24 % obtain a copy of the License at %
26 % http://www.imagemagick.org/script/license.php %
28 % Unless required by applicable law or agreed to in writing, software %
29 % distributed under the License is distributed on an "AS IS" BASIS, %
30 % WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. %
31 % See the License for the specific language governing permissions and %
32 % limitations under the License. %
34 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
43 #include "MagickCore/studio.h"
44 #include "MagickCore/blob.h"
45 #include "MagickCore/blob-private.h"
46 #include "MagickCore/cache.h"
47 #include "MagickCore/cache-private.h"
48 #include "MagickCore/color-private.h"
49 #include "MagickCore/composite-private.h"
50 #include "MagickCore/constitute.h"
51 #include "MagickCore/exception.h"
52 #include "MagickCore/exception-private.h"
53 #include "MagickCore/geometry.h"
54 #include "MagickCore/memory_.h"
55 #include "MagickCore/pixel.h"
56 #include "MagickCore/pixel-accessor.h"
57 #include "MagickCore/quantum.h"
58 #include "MagickCore/quantum-private.h"
59 #include "MagickCore/semaphore.h"
60 #include "MagickCore/stream.h"
61 #include "MagickCore/stream-private.h"
62 #include "MagickCore/string_.h"
65 Typedef declaractions.
107 Declare pixel cache interfaces.
109 #if defined(__cplusplus) || defined(c_plusplus)
114 *GetVirtualPixelStream(const Image *,const VirtualPixelMethod,const ssize_t,
115 const ssize_t,const size_t,const size_t,ExceptionInfo *);
117 static MagickBooleanType
118 StreamImagePixels(const StreamInfo *,const Image *,ExceptionInfo *),
119 SyncAuthenticPixelsStream(Image *,ExceptionInfo *);
122 *QueueAuthenticPixelsStream(Image *,const ssize_t,const ssize_t,const size_t,
123 const size_t,ExceptionInfo *);
125 #if defined(__cplusplus) || defined(c_plusplus)
130 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
134 + A c q u i r e S t r e a m I n f o %
138 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
140 % AcquireStreamInfo() allocates the StreamInfo structure.
142 % The format of the AcquireStreamInfo method is:
144 % StreamInfo *AcquireStreamInfo(const ImageInfo *image_info,
145 % ExceptionInfo *exception)
147 % A description of each parameter follows:
149 % o image_info: the image info.
151 % o exception: return any errors or warnings in this structure.
154 MagickExport StreamInfo *AcquireStreamInfo(const ImageInfo *image_info,
155 ExceptionInfo *exception)
160 stream_info=(StreamInfo *) AcquireMagickMemory(sizeof(*stream_info));
161 if (stream_info == (StreamInfo *) NULL)
162 ThrowFatalException(ResourceLimitFatalError,"MemoryAllocationFailed");
163 (void) ResetMagickMemory(stream_info,0,sizeof(*stream_info));
164 stream_info->pixels=(unsigned char *) AcquireMagickMemory(
165 sizeof(*stream_info->pixels));
166 if (stream_info->pixels == (unsigned char *) NULL)
167 ThrowFatalException(ResourceLimitFatalError,"MemoryAllocationFailed");
168 stream_info->map=ConstantString("RGB");
169 stream_info->storage_type=CharPixel;
170 stream_info->stream=AcquireImage(image_info,exception);
171 stream_info->signature=MagickSignature;
176 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
180 + D e s t r o y P i x e l S t r e a m %
184 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
186 % DestroyPixelStream() deallocates memory associated with the pixel stream.
188 % The format of the DestroyPixelStream() method is:
190 % void DestroyPixelStream(Image *image)
192 % A description of each parameter follows:
194 % o image: the image.
198 static inline void RelinquishStreamPixels(CacheInfo *cache_info)
200 assert(cache_info != (CacheInfo *) NULL);
201 if (cache_info->mapped == MagickFalse)
202 (void) RelinquishMagickMemory(cache_info->pixels);
204 (void) UnmapBlob(cache_info->pixels,(size_t) cache_info->length);
205 cache_info->pixels=(Quantum *) NULL;
206 cache_info->metacontent=(void *) NULL;
207 cache_info->length=0;
208 cache_info->mapped=MagickFalse;
211 static void DestroyPixelStream(Image *image)
219 assert(image != (Image *) NULL);
220 assert(image->signature == MagickSignature);
221 if (image->debug != MagickFalse)
222 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
223 cache_info=(CacheInfo *) image->cache;
224 assert(cache_info->signature == MagickSignature);
226 LockSemaphoreInfo(cache_info->semaphore);
227 cache_info->reference_count--;
228 if (cache_info->reference_count == 0)
230 UnlockSemaphoreInfo(cache_info->semaphore);
231 if (destroy == MagickFalse)
233 RelinquishStreamPixels(cache_info);
234 if (cache_info->nexus_info != (NexusInfo **) NULL)
235 cache_info->nexus_info=DestroyPixelCacheNexus(cache_info->nexus_info,
236 cache_info->number_threads);
237 if (cache_info->disk_semaphore != (SemaphoreInfo *) NULL)
238 DestroySemaphoreInfo(&cache_info->disk_semaphore);
239 if (cache_info->semaphore != (SemaphoreInfo *) NULL)
240 DestroySemaphoreInfo(&cache_info->semaphore);
241 cache_info=(CacheInfo *) RelinquishMagickMemory(cache_info);
245 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
249 + D e s t r o y S t r e a m I n f o %
253 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
255 % DestroyStreamInfo() destroys memory associated with the StreamInfo
258 % The format of the DestroyStreamInfo method is:
260 % StreamInfo *DestroyStreamInfo(StreamInfo *stream_info)
262 % A description of each parameter follows:
264 % o stream_info: the stream info.
267 MagickExport StreamInfo *DestroyStreamInfo(StreamInfo *stream_info)
269 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
270 assert(stream_info != (StreamInfo *) NULL);
271 assert(stream_info->signature == MagickSignature);
272 if (stream_info->map != (char *) NULL)
273 stream_info->map=DestroyString(stream_info->map);
274 if (stream_info->pixels != (unsigned char *) NULL)
275 stream_info->pixels=(unsigned char *) RelinquishMagickMemory(
276 stream_info->pixels);
277 if (stream_info->stream != (Image *) NULL)
279 (void) CloseBlob(stream_info->stream);
280 stream_info->stream=DestroyImage(stream_info->stream);
282 if (stream_info->quantum_info != (QuantumInfo *) NULL)
283 stream_info->quantum_info=DestroyQuantumInfo(stream_info->quantum_info);
284 stream_info->signature=(~MagickSignature);
285 stream_info=(StreamInfo *) RelinquishMagickMemory(stream_info);
290 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
294 + G e t A u t h e n t i c M e t a c o n t e n t F r o m S t r e a m %
298 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
300 % GetAuthenticMetacontentFromStream() returns the metacontent corresponding
301 % with the last call to QueueAuthenticPixelsStream() or
302 % GetAuthenticPixelsStream().
304 % The format of the GetAuthenticMetacontentFromStream() method is:
306 % void *GetAuthenticMetacontentFromStream(const Image *image)
308 % A description of each parameter follows:
310 % o image: the image.
313 static void *GetAuthenticMetacontentFromStream(const Image *image)
318 assert(image != (Image *) NULL);
319 assert(image->signature == MagickSignature);
320 if (image->debug != MagickFalse)
321 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
322 cache_info=(CacheInfo *) image->cache;
323 assert(cache_info->signature == MagickSignature);
324 return(cache_info->metacontent);
328 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
332 + G e t A u t h e n t i c P i x e l S t r e a m %
336 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
338 % GetAuthenticPixelsStream() gets pixels from the in-memory or disk pixel
339 % cache as defined by the geometry parameters. A pointer to the pixels is
340 % returned if the pixels are transferred, otherwise a NULL is returned. For
341 % streams this method is a no-op.
343 % The format of the GetAuthenticPixelsStream() method is:
345 % Quantum *GetAuthenticPixelsStream(Image *image,const ssize_t x,
346 % const ssize_t y,const size_t columns,const size_t rows,
347 % ExceptionInfo *exception)
349 % A description of each parameter follows:
351 % o image: the image.
353 % o x,y,columns,rows: These values define the perimeter of a region of
356 % o exception: return any errors or warnings in this structure.
359 static Quantum *GetAuthenticPixelsStream(Image *image,const ssize_t x,
360 const ssize_t y,const size_t columns,const size_t rows,
361 ExceptionInfo *exception)
366 assert(image != (Image *) NULL);
367 assert(image->signature == MagickSignature);
368 if (image->debug != MagickFalse)
369 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
370 pixels=QueueAuthenticPixelsStream(image,x,y,columns,rows,exception);
375 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
379 + G e t A u t h e n t i c P i x e l F r o m S t e a m %
383 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
385 % GetAuthenticPixelsFromStream() returns the pixels associated with the last
386 % call to QueueAuthenticPixelsStream() or GetAuthenticPixelsStream().
388 % The format of the GetAuthenticPixelsFromStream() method is:
390 % Quantum *GetAuthenticPixelsFromStream(const Image image)
392 % A description of each parameter follows:
394 % o image: the image.
397 static Quantum *GetAuthenticPixelsFromStream(const Image *image)
402 assert(image != (Image *) NULL);
403 assert(image->signature == MagickSignature);
404 if (image->debug != MagickFalse)
405 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
406 cache_info=(CacheInfo *) image->cache;
407 assert(cache_info->signature == MagickSignature);
408 return(cache_info->pixels);
412 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
416 + G e t O n e A u t h e n t i c P i x e l F r o m S t r e a m %
420 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
422 % GetOneAuthenticPixelFromStream() returns a single pixel at the specified
423 % (x,y) location. The image background color is returned if an error occurs.
425 % The format of the GetOneAuthenticPixelFromStream() method is:
427 % MagickBooleanType GetOneAuthenticPixelFromStream(const Image image,
428 % const ssize_t x,const ssize_t y,Quantum *pixel,
429 % ExceptionInfo *exception)
431 % A description of each parameter follows:
433 % o image: the image.
435 % o pixel: return a pixel at the specified (x,y) location.
437 % o x,y: These values define the location of the pixel to return.
439 % o exception: return any errors or warnings in this structure.
442 static MagickBooleanType GetOneAuthenticPixelFromStream(Image *image,
443 const ssize_t x,const ssize_t y,Quantum *pixel,ExceptionInfo *exception)
451 assert(image != (Image *) NULL);
452 assert(image->signature == MagickSignature);
453 (void) memset(pixel,0,MaxPixelChannels*sizeof(*pixel));
454 q=GetAuthenticPixelsStream(image,x,y,1,1,exception);
455 if (q != (Quantum *) NULL)
457 pixel[RedPixelChannel]=ClampToQuantum(image->background_color.red);
458 pixel[GreenPixelChannel]=ClampToQuantum(image->background_color.green);
459 pixel[BluePixelChannel]=ClampToQuantum(image->background_color.blue);
460 pixel[BlackPixelChannel]=ClampToQuantum(image->background_color.black);
461 pixel[AlphaPixelChannel]=ClampToQuantum(image->background_color.alpha);
464 for (i=0; i < (ssize_t) GetPixelChannels(image); i++)
469 channel=GetPixelChannelMapChannel(image,i);
476 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
480 + G e t O n e V i r t u a l P i x e l F r o m S t r e a m %
484 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
486 % GetOneVirtualPixelFromStream() returns a single pixel at the specified
487 % (x.y) location. The image background color is returned if an error occurs.
489 % The format of the GetOneVirtualPixelFromStream() method is:
491 % MagickBooleanType GetOneVirtualPixelFromStream(const Image image,
492 % const VirtualPixelMethod virtual_pixel_method,const ssize_t x,
493 % const ssize_t y,Quantum *pixel,ExceptionInfo *exception)
495 % A description of each parameter follows:
497 % o image: the image.
499 % o virtual_pixel_method: the virtual pixel method.
501 % o x,y: These values define the location of the pixel to return.
503 % o pixel: return a pixel at the specified (x,y) location.
505 % o exception: return any errors or warnings in this structure.
508 static MagickBooleanType GetOneVirtualPixelFromStream(const Image *image,
509 const VirtualPixelMethod virtual_pixel_method,const ssize_t x,const ssize_t y,
510 Quantum *pixel,ExceptionInfo *exception)
518 assert(image != (Image *) NULL);
519 assert(image->signature == MagickSignature);
520 (void) memset(pixel,0,MaxPixelChannels*sizeof(*pixel));
521 p=GetVirtualPixelStream(image,virtual_pixel_method,x,y,1,1,exception);
522 if (p == (const Quantum *) NULL)
524 pixel[RedPixelChannel]=ClampToQuantum(image->background_color.red);
525 pixel[GreenPixelChannel]=ClampToQuantum(image->background_color.green);
526 pixel[BluePixelChannel]=ClampToQuantum(image->background_color.blue);
527 pixel[BlackPixelChannel]=ClampToQuantum(image->background_color.black);
528 pixel[AlphaPixelChannel]=ClampToQuantum(image->background_color.alpha);
531 for (i=0; i < (ssize_t) GetPixelChannels(image); i++)
536 channel=GetPixelChannelMapChannel(image,i);
543 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
547 + G e t S t r e a m I n f o C l i e n t D a t a %
551 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
553 % GetStreamInfoClientData() gets the stream info client data.
555 % The format of the GetStreamInfoClientData method is:
557 % const void *GetStreamInfoClientData(StreamInfo *stream_info)
559 % A description of each parameter follows:
561 % o stream_info: the stream info.
564 MagickPrivate const void *GetStreamInfoClientData(StreamInfo *stream_info)
566 assert(stream_info != (StreamInfo *) NULL);
567 assert(stream_info->signature == MagickSignature);
568 return(stream_info->client_data);
572 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
576 + G e t V i r t u a l P i x e l s F r o m S t r e a m %
580 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
582 % GetVirtualPixelsStream() returns the pixels associated with the last
583 % call to QueueAuthenticPixelsStream() or GetVirtualPixelStream().
585 % The format of the GetVirtualPixelsStream() method is:
587 % const Quantum *GetVirtualPixelsStream(const Image *image)
589 % A description of each parameter follows:
591 % o pixels: return the pixels associated corresponding with the last call to
592 % QueueAuthenticPixelsStream() or GetVirtualPixelStream().
594 % o image: the image.
597 static const Quantum *GetVirtualPixelsStream(const Image *image)
602 assert(image != (Image *) NULL);
603 assert(image->signature == MagickSignature);
604 if (image->debug != MagickFalse)
605 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
606 cache_info=(CacheInfo *) image->cache;
607 assert(cache_info->signature == MagickSignature);
608 return(cache_info->pixels);
612 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
616 + G e t V i r t u a l I n d e x e s F r o m S t r e a m %
620 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
622 % GetVirtualMetacontentFromStream() returns the associated pixel
623 % channels corresponding with the last call to QueueAuthenticPixelsStream() or
624 % GetVirtualPixelStream().
626 % The format of the GetVirtualMetacontentFromStream() method is:
628 % const void *GetVirtualMetacontentFromStream(const Image *image)
630 % A description of each parameter follows:
632 % o image: the image.
635 static const void *GetVirtualMetacontentFromStream(
641 assert(image != (Image *) NULL);
642 assert(image->signature == MagickSignature);
643 if (image->debug != MagickFalse)
644 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
645 cache_info=(CacheInfo *) image->cache;
646 assert(cache_info->signature == MagickSignature);
647 return(cache_info->metacontent);
651 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
655 + G e t V i r t u a l P i x e l S t r e a m %
659 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
661 % GetVirtualPixelStream() gets pixels from the in-memory or disk pixel cache as
662 % defined by the geometry parameters. A pointer to the pixels is returned if
663 % the pixels are transferred, otherwise a NULL is returned. For streams this
666 % The format of the GetVirtualPixelStream() method is:
668 % const Quantum *GetVirtualPixelStream(const Image *image,
669 % const VirtualPixelMethod virtual_pixel_method,const ssize_t x,
670 % const ssize_t y,const size_t columns,const size_t rows,
671 % ExceptionInfo *exception)
673 % A description of each parameter follows:
675 % o image: the image.
677 % o virtual_pixel_method: the virtual pixel method.
679 % o x,y,columns,rows: These values define the perimeter of a region of
682 % o exception: return any errors or warnings in this structure.
686 static inline MagickBooleanType AcquireStreamPixels(CacheInfo *cache_info,
687 ExceptionInfo *exception)
689 if (cache_info->length != (MagickSizeType) ((size_t) cache_info->length))
691 cache_info->mapped=MagickFalse;
692 cache_info->pixels=(Quantum *) AcquireMagickMemory((size_t)
694 if (cache_info->pixels == (Quantum *) NULL)
696 cache_info->mapped=MagickTrue;
697 cache_info->pixels=(Quantum *) MapBlob(-1,IOMode,0,(size_t)
700 if (cache_info->pixels == (Quantum *) NULL)
702 (void) ThrowMagickException(exception,GetMagickModule(),
703 ResourceLimitError,"MemoryAllocationFailed","'%s'",
704 cache_info->filename);
710 static const Quantum *GetVirtualPixelStream(const Image *image,
711 const VirtualPixelMethod magick_unused(virtual_pixel_method),const ssize_t x,
712 const ssize_t y,const size_t columns,const size_t rows,
713 ExceptionInfo *exception)
728 Validate pixel cache geometry.
730 assert(image != (const Image *) NULL);
731 assert(image->signature == MagickSignature);
732 if (image->debug != MagickFalse)
733 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
734 if ((x < 0) || (y < 0) ||
735 ((x+(ssize_t) columns) > (ssize_t) image->columns) ||
736 ((y+(ssize_t) rows) > (ssize_t) image->rows) ||
737 (columns == 0) || (rows == 0))
739 (void) ThrowMagickException(exception,GetMagickModule(),StreamError,
740 "ImageDoesNotContainTheStreamGeometry","'%s'",image->filename);
741 return((Quantum *) NULL);
743 cache_info=(CacheInfo *) image->cache;
744 assert(cache_info->signature == MagickSignature);
746 Pixels are stored in a temporary buffer until they are synced to the cache.
748 number_pixels=(MagickSizeType) columns*rows;
749 length=(size_t) number_pixels*cache_info->number_channels*sizeof(Quantum);
750 if (cache_info->metacontent_extent != 0)
751 length+=number_pixels*cache_info->metacontent_extent;
752 if (cache_info->pixels == (Quantum *) NULL)
754 cache_info->length=length;
755 status=AcquireStreamPixels(cache_info,exception);
756 if (status == MagickFalse)
758 cache_info->length=0;
759 return((Quantum *) NULL);
763 if (cache_info->length != length)
765 RelinquishStreamPixels(cache_info);
766 cache_info->length=length;
767 status=AcquireStreamPixels(cache_info,exception);
768 if (status == MagickFalse)
770 cache_info->length=0;
771 return((Quantum *) NULL);
774 cache_info->metacontent=(void *) NULL;
775 if (cache_info->metacontent_extent != 0)
776 cache_info->metacontent=(void *) (cache_info->pixels+number_pixels*
777 cache_info->number_channels);
778 return(cache_info->pixels);
782 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
786 + O p e n S t r e a m %
790 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
792 % OpenStream() opens a stream for writing by the StreamImage() method.
794 % The format of the OpenStream method is:
796 % MagickBooleanType OpenStream(const ImageInfo *image_info,
797 % StreamInfo *stream_info,const char *filename,ExceptionInfo *exception)
799 % A description of each parameter follows:
801 % o image_info: the image info.
803 % o stream_info: the stream info.
805 % o filename: the stream filename.
807 % o exception: return any errors or warnings in this structure.
810 MagickExport MagickBooleanType OpenStream(const ImageInfo *image_info,
811 StreamInfo *stream_info,const char *filename,ExceptionInfo *exception)
816 (void) CopyMagickString(stream_info->stream->filename,filename,MaxTextExtent);
817 status=OpenBlob(image_info,stream_info->stream,WriteBinaryBlobMode,exception);
822 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
826 + Q u e u e A u t h e n t i c P i x e l s S t r e a m %
830 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
832 % QueueAuthenticPixelsStream() allocates an area to store image pixels as
833 % defined by the region rectangle and returns a pointer to the area. This
834 % area is subsequently transferred from the pixel cache with method
835 % SyncAuthenticPixelsStream(). A pointer to the pixels is returned if the
836 % pixels are transferred, otherwise a NULL is returned.
838 % The format of the QueueAuthenticPixelsStream() method is:
840 % Quantum *QueueAuthenticPixelsStream(Image *image,const ssize_t x,
841 % const ssize_t y,const size_t columns,const size_t rows,
842 % ExceptionInfo *exception)
844 % A description of each parameter follows:
846 % o image: the image.
848 % o x,y,columns,rows: These values define the perimeter of a region of
852 static Quantum *QueueAuthenticPixelsStream(Image *image,const ssize_t x,
853 const ssize_t y,const size_t columns,const size_t rows,
854 ExceptionInfo *exception)
869 Validate pixel cache geometry.
871 assert(image != (Image *) NULL);
872 if ((x < 0) || (y < 0) ||
873 ((x+(ssize_t) columns) > (ssize_t) image->columns) ||
874 ((y+(ssize_t) rows) > (ssize_t) image->rows) ||
875 (columns == 0) || (rows == 0))
877 (void) ThrowMagickException(exception,GetMagickModule(),StreamError,
878 "ImageDoesNotContainTheStreamGeometry","'%s'",image->filename);
879 return((Quantum *) NULL);
881 stream_handler=GetBlobStreamHandler(image);
882 if (stream_handler == (StreamHandler) NULL)
884 (void) ThrowMagickException(exception,GetMagickModule(),StreamError,
885 "NoStreamHandlerIsDefined","'%s'",image->filename);
886 return((Quantum *) NULL);
888 cache_info=(CacheInfo *) image->cache;
889 assert(cache_info->signature == MagickSignature);
890 if ((image->storage_class != GetPixelCacheStorageClass(image->cache)) ||
891 (image->colorspace != GetPixelCacheColorspace(image->cache)))
893 if (GetPixelCacheStorageClass(image->cache) == UndefinedClass)
894 (void) stream_handler(image,(const void *) NULL,(size_t)
895 cache_info->columns);
896 cache_info->storage_class=image->storage_class;
897 cache_info->colorspace=image->colorspace;
898 cache_info->columns=image->columns;
899 cache_info->rows=image->rows;
900 image->cache=cache_info;
903 Pixels are stored in a temporary buffer until they are synced to the cache.
905 cache_info->columns=columns;
906 cache_info->rows=rows;
907 number_pixels=(MagickSizeType) columns*rows;
908 length=(size_t) number_pixels*cache_info->number_channels*sizeof(Quantum);
909 if (cache_info->metacontent_extent != 0)
910 length+=number_pixels*cache_info->metacontent_extent;
911 if (cache_info->pixels == (Quantum *) NULL)
913 cache_info->pixels=(Quantum *) AcquireMagickMemory(length);
914 cache_info->length=(MagickSizeType) length;
917 if (cache_info->length < (MagickSizeType) length)
919 cache_info->pixels=(Quantum *) ResizeMagickMemory(
920 cache_info->pixels,length);
921 cache_info->length=(MagickSizeType) length;
923 if (cache_info->pixels == (void *) NULL)
924 return((Quantum *) NULL);
925 cache_info->metacontent=(void *) NULL;
926 if (cache_info->metacontent_extent != 0)
927 cache_info->metacontent=(void *) (cache_info->pixels+number_pixels*
928 cache_info->number_channels);
929 return(cache_info->pixels);
933 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
937 % R e a d S t r e a m %
941 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
943 % ReadStream() makes the image pixels available to a user supplied callback
944 % method immediately upon reading a scanline with the ReadImage() method.
946 % The format of the ReadStream() method is:
948 % Image *ReadStream(const ImageInfo *image_info,StreamHandler stream,
949 % ExceptionInfo *exception)
951 % A description of each parameter follows:
953 % o image_info: the image info.
955 % o stream: a callback method.
957 % o exception: return any errors or warnings in this structure.
960 MagickExport Image *ReadStream(const ImageInfo *image_info,StreamHandler stream,
961 ExceptionInfo *exception)
975 assert(image_info != (ImageInfo *) NULL);
976 assert(image_info->signature == MagickSignature);
977 if (image_info->debug != MagickFalse)
978 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",
979 image_info->filename);
980 assert(exception != (ExceptionInfo *) NULL);
981 assert(exception->signature == MagickSignature);
982 read_info=CloneImageInfo(image_info);
983 read_info->cache=AcquirePixelCache(0);
984 GetPixelCacheMethods(&cache_methods);
985 cache_methods.get_virtual_pixel_handler=GetVirtualPixelStream;
986 cache_methods.get_virtual_metacontent_from_handler=
987 GetVirtualMetacontentFromStream;
988 cache_methods.get_virtual_pixels_handler=GetVirtualPixelsStream;
989 cache_methods.get_authentic_pixels_handler=GetAuthenticPixelsStream;
990 cache_methods.queue_authentic_pixels_handler=QueueAuthenticPixelsStream;
991 cache_methods.sync_authentic_pixels_handler=SyncAuthenticPixelsStream;
992 cache_methods.get_authentic_pixels_from_handler=GetAuthenticPixelsFromStream;
993 cache_methods.get_authentic_metacontent_from_handler=
994 GetAuthenticMetacontentFromStream;
995 cache_methods.get_one_virtual_pixel_from_handler=GetOneVirtualPixelFromStream;
996 cache_methods.get_one_authentic_pixel_from_handler=
997 GetOneAuthenticPixelFromStream;
998 cache_methods.destroy_pixel_handler=DestroyPixelStream;
999 SetPixelCacheMethods(read_info->cache,&cache_methods);
1000 read_info->stream=stream;
1001 image=ReadImage(read_info,exception);
1002 read_info=DestroyImageInfo(read_info);
1007 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1011 + S e t S t r e a m I n f o C l i e n t D a t a %
1015 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1017 % SetStreamInfoClientData() sets the stream info client data.
1019 % The format of the SetStreamInfoClientData method is:
1021 % void SetStreamInfoClientData(StreamInfo *stream_info,
1022 % const void *client_data)
1024 % A description of each parameter follows:
1026 % o stream_info: the stream info.
1028 % o client_data: the client data.
1031 MagickPrivate void SetStreamInfoClientData(StreamInfo *stream_info,
1032 const void *client_data)
1034 assert(stream_info != (StreamInfo *) NULL);
1035 assert(stream_info->signature == MagickSignature);
1036 stream_info->client_data=client_data;
1040 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1044 + S e t S t r e a m I n f o M a p %
1048 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1050 % SetStreamInfoMap() sets the stream info map member.
1052 % The format of the SetStreamInfoMap method is:
1054 % void SetStreamInfoMap(StreamInfo *stream_info,const char *map)
1056 % A description of each parameter follows:
1058 % o stream_info: the stream info.
1063 MagickExport void SetStreamInfoMap(StreamInfo *stream_info,const char *map)
1065 assert(stream_info != (StreamInfo *) NULL);
1066 assert(stream_info->signature == MagickSignature);
1067 (void) CloneString(&stream_info->map,map);
1071 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1075 + S e t S t r e a m I n f o S t o r a g e T y p e %
1079 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1081 % SetStreamInfoStorageType() sets the stream info storage type member.
1083 % The format of the SetStreamInfoStorageType method is:
1085 % void SetStreamInfoStorageType(StreamInfo *stream_info,
1086 % const StoreageType *storage_type)
1088 % A description of each parameter follows:
1090 % o stream_info: the stream info.
1092 % o storage_type: the storage type.
1095 MagickExport void SetStreamInfoStorageType(StreamInfo *stream_info,
1096 const StorageType storage_type)
1098 assert(stream_info != (StreamInfo *) NULL);
1099 assert(stream_info->signature == MagickSignature);
1100 stream_info->storage_type=storage_type;
1104 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1108 + S t r e a m I m a g e %
1112 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1114 % StreamImage() streams pixels from an image and writes them in a user
1115 % defined format and storage type (e.g. RGBA as 8-bit unsigned char).
1117 % The format of the StreamImage() method is:
1119 % Image *StreamImage(const ImageInfo *image_info,
1120 % StreamInfo *stream_info,ExceptionInfo *exception)
1122 % A description of each parameter follows:
1124 % o image_info: the image info.
1126 % o stream_info: the stream info.
1128 % o exception: return any errors or warnings in this structure.
1132 #if defined(__cplusplus) || defined(c_plusplus)
1136 static size_t WriteStreamImage(const Image *image,const void *pixels,
1137 const size_t columns)
1156 stream_info=(StreamInfo *) image->client_data;
1157 switch (stream_info->storage_type)
1159 default: packet_size=sizeof(unsigned char); break;
1160 case CharPixel: packet_size=sizeof(unsigned char); break;
1161 case DoublePixel: packet_size=sizeof(double); break;
1162 case FloatPixel: packet_size=sizeof(float); break;
1163 case LongPixel: packet_size=sizeof(unsigned int); break;
1164 case LongLongPixel: packet_size=sizeof(MagickSizeType); break;
1165 case QuantumPixel: packet_size=sizeof(Quantum); break;
1166 case ShortPixel: packet_size=sizeof(unsigned short); break;
1168 cache_info=(CacheInfo *) image->cache;
1169 assert(cache_info->signature == MagickSignature);
1170 packet_size*=strlen(stream_info->map);
1171 length=packet_size*cache_info->columns*cache_info->rows;
1172 if (image != stream_info->image)
1178 Prepare stream for writing.
1180 stream_info->pixels=(unsigned char *) ResizeQuantumMemory(
1181 stream_info->pixels,length,sizeof(*stream_info->pixels));
1182 if (stream_info->pixels == (unsigned char *) NULL)
1184 stream_info->image=image;
1185 write_info=CloneImageInfo(stream_info->image_info);
1186 (void) SetImageInfo(write_info,1,stream_info->exception);
1187 if (write_info->extract != (char *) NULL)
1188 (void) ParseAbsoluteGeometry(write_info->extract,
1189 &stream_info->extract_info);
1191 write_info=DestroyImageInfo(write_info);
1193 extract_info=stream_info->extract_info;
1194 if ((extract_info.width == 0) || (extract_info.height == 0))
1197 Write all pixels to stream.
1199 (void) StreamImagePixels(stream_info,image,stream_info->exception);
1200 count=WriteBlob(stream_info->stream,length,stream_info->pixels);
1202 return(count == 0 ? 0 : columns);
1204 if ((stream_info->y < extract_info.y) ||
1205 (stream_info->y >= (ssize_t) (extract_info.y+extract_info.height)))
1211 Write a portion of the pixel row to the stream.
1213 (void) StreamImagePixels(stream_info,image,stream_info->exception);
1214 length=packet_size*extract_info.width;
1215 count=WriteBlob(stream_info->stream,length,stream_info->pixels+packet_size*
1218 return(count == 0 ? 0 : columns);
1221 #if defined(__cplusplus) || defined(c_plusplus)
1225 MagickExport Image *StreamImage(const ImageInfo *image_info,
1226 StreamInfo *stream_info,ExceptionInfo *exception)
1234 assert(image_info != (const ImageInfo *) NULL);
1235 assert(image_info->signature == MagickSignature);
1236 if (image_info->debug != MagickFalse)
1237 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",
1238 image_info->filename);
1239 assert(stream_info != (StreamInfo *) NULL);
1240 assert(stream_info->signature == MagickSignature);
1241 assert(exception != (ExceptionInfo *) NULL);
1242 read_info=CloneImageInfo(image_info);
1243 stream_info->image_info=image_info;
1244 stream_info->exception=exception;
1245 read_info->client_data=(void *) stream_info;
1246 image=ReadStream(read_info,&WriteStreamImage,exception);
1247 read_info=DestroyImageInfo(read_info);
1248 stream_info->quantum_info=AcquireQuantumInfo(image_info,image);
1249 if (stream_info->quantum_info == (QuantumInfo *) NULL)
1250 image=DestroyImage(image);
1255 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1259 + S t r e a m I m a g e P i x e l s %
1263 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1265 % StreamImagePixels() extracts pixel data from an image and returns it in the
1266 % stream_info->pixels structure in the format as defined by
1267 % stream_info->quantum_info->map and stream_info->quantum_info->storage_type.
1269 % The format of the StreamImagePixels method is:
1271 % MagickBooleanType StreamImagePixels(const StreamInfo *stream_info,
1272 % const Image *image,ExceptionInfo *exception)
1274 % A description of each parameter follows:
1276 % o stream_info: the stream info.
1278 % o image: the image.
1280 % o exception: return any errors or warnings in this structure.
1283 static MagickBooleanType StreamImagePixels(const StreamInfo *stream_info,
1284 const Image *image,ExceptionInfo *exception)
1292 register const Quantum
1302 assert(stream_info != (StreamInfo *) NULL);
1303 assert(stream_info->signature == MagickSignature);
1304 assert(image != (Image *) NULL);
1305 assert(image->signature == MagickSignature);
1306 if (image->debug != MagickFalse)
1307 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
1308 length=strlen(stream_info->map);
1309 quantum_map=(QuantumType *) AcquireQuantumMemory(length,sizeof(*quantum_map));
1310 if (quantum_map == (QuantumType *) NULL)
1312 (void) ThrowMagickException(exception,GetMagickModule(),
1313 ResourceLimitError,"MemoryAllocationFailed","'%s'",image->filename);
1314 return(MagickFalse);
1316 for (i=0; i < (ssize_t) length; i++)
1318 switch (stream_info->map[i])
1323 quantum_map[i]=AlphaQuantum;
1329 quantum_map[i]=BlueQuantum;
1335 quantum_map[i]=CyanQuantum;
1336 if (image->colorspace == CMYKColorspace)
1338 quantum_map=(QuantumType *) RelinquishMagickMemory(quantum_map);
1339 (void) ThrowMagickException(exception,GetMagickModule(),ImageError,
1340 "ColorSeparatedImageRequired","'%s'",stream_info->map);
1341 return(MagickFalse);
1346 quantum_map[i]=GreenQuantum;
1352 quantum_map[i]=IndexQuantum;
1358 quantum_map[i]=BlackQuantum;
1359 if (image->colorspace == CMYKColorspace)
1361 quantum_map=(QuantumType *) RelinquishMagickMemory(quantum_map);
1362 (void) ThrowMagickException(exception,GetMagickModule(),ImageError,
1363 "ColorSeparatedImageRequired","'%s'",stream_info->map);
1364 return(MagickFalse);
1369 quantum_map[i]=MagentaQuantum;
1370 if (image->colorspace == CMYKColorspace)
1372 quantum_map=(QuantumType *) RelinquishMagickMemory(quantum_map);
1373 (void) ThrowMagickException(exception,GetMagickModule(),ImageError,
1374 "ColorSeparatedImageRequired","'%s'",stream_info->map);
1375 return(MagickFalse);
1380 quantum_map[i]=OpacityQuantum;
1386 quantum_map[i]=UndefinedQuantum;
1392 quantum_map[i]=RedQuantum;
1398 quantum_map[i]=YellowQuantum;
1399 if (image->colorspace == CMYKColorspace)
1401 quantum_map=(QuantumType *) RelinquishMagickMemory(quantum_map);
1402 (void) ThrowMagickException(exception,GetMagickModule(),ImageError,
1403 "ColorSeparatedImageRequired","'%s'",stream_info->map);
1404 return(MagickFalse);
1408 quantum_map=(QuantumType *) RelinquishMagickMemory(quantum_map);
1409 (void) ThrowMagickException(exception,GetMagickModule(),OptionError,
1410 "UnrecognizedPixelMap","'%s'",stream_info->map);
1411 return(MagickFalse);
1415 quantum_info=stream_info->quantum_info;
1416 switch (stream_info->storage_type)
1420 register unsigned char
1423 q=(unsigned char *) stream_info->pixels;
1424 if (LocaleCompare(stream_info->map,"BGR") == 0)
1426 p=GetVirtualPixelQueue(image);
1427 if (p == (const Quantum *) NULL)
1429 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1431 *q++=ScaleQuantumToChar(GetPixelBlue(image,p));
1432 *q++=ScaleQuantumToChar(GetPixelGreen(image,p));
1433 *q++=ScaleQuantumToChar(GetPixelRed(image,p));
1438 if (LocaleCompare(stream_info->map,"BGRA") == 0)
1440 p=GetVirtualPixelQueue(image);
1441 if (p == (const Quantum *) NULL)
1443 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1445 *q++=ScaleQuantumToChar(GetPixelBlue(image,p));
1446 *q++=ScaleQuantumToChar(GetPixelGreen(image,p));
1447 *q++=ScaleQuantumToChar(GetPixelRed(image,p));
1448 *q++=ScaleQuantumToChar(GetPixelAlpha(image,p));
1453 if (LocaleCompare(stream_info->map,"BGRP") == 0)
1455 p=GetVirtualPixelQueue(image);
1456 if (p == (const Quantum *) NULL)
1458 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1460 *q++=ScaleQuantumToChar(GetPixelBlue(image,p));
1461 *q++=ScaleQuantumToChar(GetPixelGreen(image,p));
1462 *q++=ScaleQuantumToChar(GetPixelRed(image,p));
1463 *q++=ScaleQuantumToChar((Quantum) 0);
1468 if (LocaleCompare(stream_info->map,"I") == 0)
1470 p=GetVirtualPixelQueue(image);
1471 if (p == (const Quantum *) NULL)
1473 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1475 *q++=ScaleQuantumToChar(GetPixelIntensity(image,p));
1480 if (LocaleCompare(stream_info->map,"RGB") == 0)
1482 p=GetVirtualPixelQueue(image);
1483 if (p == (const Quantum *) NULL)
1485 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1487 *q++=ScaleQuantumToChar(GetPixelRed(image,p));
1488 *q++=ScaleQuantumToChar(GetPixelGreen(image,p));
1489 *q++=ScaleQuantumToChar(GetPixelBlue(image,p));
1494 if (LocaleCompare(stream_info->map,"RGBA") == 0)
1496 p=GetVirtualPixelQueue(image);
1497 if (p == (const Quantum *) NULL)
1499 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1501 *q++=ScaleQuantumToChar(GetPixelRed(image,p));
1502 *q++=ScaleQuantumToChar(GetPixelGreen(image,p));
1503 *q++=ScaleQuantumToChar(GetPixelBlue(image,p));
1504 *q++=ScaleQuantumToChar((Quantum) (GetPixelAlpha(image,p)));
1509 if (LocaleCompare(stream_info->map,"RGBP") == 0)
1511 p=GetVirtualPixelQueue(image);
1512 if (p == (const Quantum *) NULL)
1514 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1516 *q++=ScaleQuantumToChar(GetPixelRed(image,p));
1517 *q++=ScaleQuantumToChar(GetPixelGreen(image,p));
1518 *q++=ScaleQuantumToChar(GetPixelBlue(image,p));
1519 *q++=ScaleQuantumToChar((Quantum) 0);
1524 p=GetVirtualPixelQueue(image);
1525 if (p == (const Quantum *) NULL)
1527 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1529 for (i=0; i < (ssize_t) length; i++)
1532 switch (quantum_map[i])
1537 *q=ScaleQuantumToChar(GetPixelRed(image,p));
1541 case MagentaQuantum:
1543 *q=ScaleQuantumToChar(GetPixelGreen(image,p));
1549 *q=ScaleQuantumToChar(GetPixelBlue(image,p));
1554 *q=ScaleQuantumToChar((Quantum) (GetPixelAlpha(image,p)));
1557 case OpacityQuantum:
1559 *q=ScaleQuantumToChar(GetPixelAlpha(image,p));
1564 if (image->colorspace == CMYKColorspace)
1565 *q=ScaleQuantumToChar(GetPixelBlack(image,p));
1570 *q=ScaleQuantumToChar(GetPixelIntensity(image,p));
1587 q=(double *) stream_info->pixels;
1588 if (LocaleCompare(stream_info->map,"BGR") == 0)
1590 p=GetVirtualPixelQueue(image);
1591 if (p == (const Quantum *) NULL)
1593 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1595 *q++=(double) ((QuantumScale*GetPixelBlue(image,p))*
1596 quantum_info->scale+quantum_info->minimum);
1597 *q++=(double) ((QuantumScale*GetPixelGreen(image,p))*
1598 quantum_info->scale+quantum_info->minimum);
1599 *q++=(double) ((QuantumScale*GetPixelRed(image,p))*
1600 quantum_info->scale+quantum_info->minimum);
1605 if (LocaleCompare(stream_info->map,"BGRA") == 0)
1607 p=GetVirtualPixelQueue(image);
1608 if (p == (const Quantum *) NULL)
1610 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1612 *q++=(double) ((QuantumScale*GetPixelBlue(image,p))*
1613 quantum_info->scale+quantum_info->minimum);
1614 *q++=(double) ((QuantumScale*GetPixelGreen(image,p))*
1615 quantum_info->scale+quantum_info->minimum);
1616 *q++=(double) ((QuantumScale*GetPixelRed(image,p))*
1617 quantum_info->scale+quantum_info->minimum);
1618 *q++=(double) ((QuantumScale*GetPixelAlpha(image,p))*
1619 quantum_info->scale+quantum_info->minimum);
1624 if (LocaleCompare(stream_info->map,"BGRP") == 0)
1626 p=GetVirtualPixelQueue(image);
1627 if (p == (const Quantum *) NULL)
1629 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1631 *q++=(double) ((QuantumScale*GetPixelBlue(image,p))*
1632 quantum_info->scale+quantum_info->minimum);
1633 *q++=(double) ((QuantumScale*GetPixelGreen(image,p))*
1634 quantum_info->scale+quantum_info->minimum);
1635 *q++=(double) ((QuantumScale*GetPixelRed(image,p))*
1636 quantum_info->scale+quantum_info->minimum);
1642 if (LocaleCompare(stream_info->map,"I") == 0)
1644 p=GetVirtualPixelQueue(image);
1645 if (p == (const Quantum *) NULL)
1647 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1649 *q++=(double) ((QuantumScale*GetPixelIntensity(image,p))*
1650 quantum_info->scale+quantum_info->minimum);
1655 if (LocaleCompare(stream_info->map,"RGB") == 0)
1657 p=GetVirtualPixelQueue(image);
1658 if (p == (const Quantum *) NULL)
1660 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1662 *q++=(double) ((QuantumScale*GetPixelRed(image,p))*
1663 quantum_info->scale+quantum_info->minimum);
1664 *q++=(double) ((QuantumScale*GetPixelGreen(image,p))*
1665 quantum_info->scale+quantum_info->minimum);
1666 *q++=(double) ((QuantumScale*GetPixelBlue(image,p))*
1667 quantum_info->scale+quantum_info->minimum);
1672 if (LocaleCompare(stream_info->map,"RGBA") == 0)
1674 p=GetVirtualPixelQueue(image);
1675 if (p == (const Quantum *) NULL)
1677 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1679 *q++=(double) ((QuantumScale*GetPixelRed(image,p))*
1680 quantum_info->scale+quantum_info->minimum);
1681 *q++=(double) ((QuantumScale*GetPixelGreen(image,p))*
1682 quantum_info->scale+quantum_info->minimum);
1683 *q++=(double) ((QuantumScale*GetPixelBlue(image,p))*
1684 quantum_info->scale+quantum_info->minimum);
1685 *q++=(double) ((QuantumScale*GetPixelAlpha(image,p))*
1686 quantum_info->scale+quantum_info->minimum);
1691 if (LocaleCompare(stream_info->map,"RGBP") == 0)
1693 p=GetVirtualPixelQueue(image);
1694 if (p == (const Quantum *) NULL)
1696 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1698 *q++=(double) ((QuantumScale*GetPixelRed(image,p))*
1699 quantum_info->scale+quantum_info->minimum);
1700 *q++=(double) ((QuantumScale*GetPixelGreen(image,p))*
1701 quantum_info->scale+quantum_info->minimum);
1702 *q++=(double) ((QuantumScale*GetPixelBlue(image,p))*
1703 quantum_info->scale+quantum_info->minimum);
1709 p=GetVirtualPixelQueue(image);
1710 if (p == (const Quantum *) NULL)
1712 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1714 for (i=0; i < (ssize_t) length; i++)
1717 switch (quantum_map[i])
1722 *q=(double) ((QuantumScale*GetPixelRed(image,p))*
1723 quantum_info->scale+quantum_info->minimum);
1727 case MagentaQuantum:
1729 *q=(double) ((QuantumScale*GetPixelGreen(image,p))*
1730 quantum_info->scale+quantum_info->minimum);
1736 *q=(double) ((QuantumScale*GetPixelBlue(image,p))*
1737 quantum_info->scale+quantum_info->minimum);
1742 *q=(double) ((QuantumScale*GetPixelAlpha(image,p))*
1743 quantum_info->scale+quantum_info->minimum);
1746 case OpacityQuantum:
1748 *q=(double) ((QuantumScale*GetPixelAlpha(image,p))*
1749 quantum_info->scale+quantum_info->minimum);
1754 if (image->colorspace == CMYKColorspace)
1755 *q=(double) ((QuantumScale*GetPixelBlack(image,p))*
1756 quantum_info->scale+quantum_info->minimum);
1761 *q=(double) ((QuantumScale*GetPixelIntensity(image,p))*
1762 quantum_info->scale+quantum_info->minimum);
1779 q=(float *) stream_info->pixels;
1780 if (LocaleCompare(stream_info->map,"BGR") == 0)
1782 p=GetVirtualPixelQueue(image);
1783 if (p == (const Quantum *) NULL)
1785 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1787 *q++=(float) ((QuantumScale*GetPixelBlue(image,p))*
1788 quantum_info->scale+quantum_info->minimum);
1789 *q++=(float) ((QuantumScale*GetPixelGreen(image,p))*
1790 quantum_info->scale+quantum_info->minimum);
1791 *q++=(float) ((QuantumScale*GetPixelRed(image,p))*
1792 quantum_info->scale+quantum_info->minimum);
1797 if (LocaleCompare(stream_info->map,"BGRA") == 0)
1799 p=GetVirtualPixelQueue(image);
1800 if (p == (const Quantum *) NULL)
1802 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1804 *q++=(float) ((QuantumScale*GetPixelBlue(image,p))*
1805 quantum_info->scale+quantum_info->minimum);
1806 *q++=(float) ((QuantumScale*GetPixelGreen(image,p))*
1807 quantum_info->scale+quantum_info->minimum);
1808 *q++=(float) ((QuantumScale*GetPixelRed(image,p))*
1809 quantum_info->scale+quantum_info->minimum);
1810 *q++=(float) ((QuantumScale*(Quantum) (GetPixelAlpha(image,p)))*
1811 quantum_info->scale+quantum_info->minimum);
1816 if (LocaleCompare(stream_info->map,"BGRP") == 0)
1818 p=GetVirtualPixelQueue(image);
1819 if (p == (const Quantum *) NULL)
1821 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1823 *q++=(float) ((QuantumScale*GetPixelBlue(image,p))*
1824 quantum_info->scale+quantum_info->minimum);
1825 *q++=(float) ((QuantumScale*GetPixelGreen(image,p))*
1826 quantum_info->scale+quantum_info->minimum);
1827 *q++=(float) ((QuantumScale*GetPixelRed(image,p))*
1828 quantum_info->scale+quantum_info->minimum);
1834 if (LocaleCompare(stream_info->map,"I") == 0)
1836 p=GetVirtualPixelQueue(image);
1837 if (p == (const Quantum *) NULL)
1839 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1841 *q++=(float) ((QuantumScale*GetPixelIntensity(image,p))*
1842 quantum_info->scale+quantum_info->minimum);
1847 if (LocaleCompare(stream_info->map,"RGB") == 0)
1849 p=GetVirtualPixelQueue(image);
1850 if (p == (const Quantum *) NULL)
1852 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1854 *q++=(float) ((QuantumScale*GetPixelRed(image,p))*
1855 quantum_info->scale+quantum_info->minimum);
1856 *q++=(float) ((QuantumScale*GetPixelGreen(image,p))*
1857 quantum_info->scale+quantum_info->minimum);
1858 *q++=(float) ((QuantumScale*GetPixelBlue(image,p))*
1859 quantum_info->scale+quantum_info->minimum);
1864 if (LocaleCompare(stream_info->map,"RGBA") == 0)
1866 p=GetVirtualPixelQueue(image);
1867 if (p == (const Quantum *) NULL)
1869 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1871 *q++=(float) ((QuantumScale*GetPixelRed(image,p))*
1872 quantum_info->scale+quantum_info->minimum);
1873 *q++=(float) ((QuantumScale*GetPixelGreen(image,p))*
1874 quantum_info->scale+quantum_info->minimum);
1875 *q++=(float) ((QuantumScale*GetPixelBlue(image,p))*
1876 quantum_info->scale+quantum_info->minimum);
1877 *q++=(float) ((QuantumScale*GetPixelAlpha(image,p))*
1878 quantum_info->scale+quantum_info->minimum);
1883 if (LocaleCompare(stream_info->map,"RGBP") == 0)
1885 p=GetVirtualPixelQueue(image);
1886 if (p == (const Quantum *) NULL)
1888 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1890 *q++=(float) ((QuantumScale*GetPixelRed(image,p))*
1891 quantum_info->scale+quantum_info->minimum);
1892 *q++=(float) ((QuantumScale*GetPixelGreen(image,p))*
1893 quantum_info->scale+quantum_info->minimum);
1894 *q++=(float) ((QuantumScale*GetPixelBlue(image,p))*
1895 quantum_info->scale+quantum_info->minimum);
1901 p=GetVirtualPixelQueue(image);
1902 if (p == (const Quantum *) NULL)
1904 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1906 for (i=0; i < (ssize_t) length; i++)
1909 switch (quantum_map[i])
1914 *q=(float) ((QuantumScale*GetPixelRed(image,p))*
1915 quantum_info->scale+quantum_info->minimum);
1919 case MagentaQuantum:
1921 *q=(float) ((QuantumScale*GetPixelGreen(image,p))*
1922 quantum_info->scale+quantum_info->minimum);
1928 *q=(float) ((QuantumScale*GetPixelBlue(image,p))*
1929 quantum_info->scale+quantum_info->minimum);
1934 *q=(float) ((QuantumScale*GetPixelAlpha(image,p))*
1935 quantum_info->scale+quantum_info->minimum);
1938 case OpacityQuantum:
1940 *q=(float) ((QuantumScale*GetPixelAlpha(image,p))*
1941 quantum_info->scale+quantum_info->minimum);
1946 if (image->colorspace == CMYKColorspace)
1947 *q=(float) ((QuantumScale*GetPixelBlack(image,p))*
1948 quantum_info->scale+quantum_info->minimum);
1953 *q=(float) ((QuantumScale*GetPixelIntensity(image,p))*
1954 quantum_info->scale+quantum_info->minimum);
1968 register unsigned int
1971 q=(unsigned int *) stream_info->pixels;
1972 if (LocaleCompare(stream_info->map,"BGR") == 0)
1974 p=GetVirtualPixelQueue(image);
1975 if (p == (const Quantum *) NULL)
1977 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1979 *q++=ScaleQuantumToLong(GetPixelBlue(image,p));
1980 *q++=ScaleQuantumToLong(GetPixelGreen(image,p));
1981 *q++=ScaleQuantumToLong(GetPixelRed(image,p));
1986 if (LocaleCompare(stream_info->map,"BGRA") == 0)
1988 p=GetVirtualPixelQueue(image);
1989 if (p == (const Quantum *) NULL)
1991 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
1993 *q++=ScaleQuantumToLong(GetPixelBlue(image,p));
1994 *q++=ScaleQuantumToLong(GetPixelGreen(image,p));
1995 *q++=ScaleQuantumToLong(GetPixelRed(image,p));
1996 *q++=ScaleQuantumToLong((Quantum) (GetPixelAlpha(image,p)));
2001 if (LocaleCompare(stream_info->map,"BGRP") == 0)
2003 p=GetVirtualPixelQueue(image);
2004 if (p == (const Quantum *) NULL)
2006 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2008 *q++=ScaleQuantumToLong(GetPixelBlue(image,p));
2009 *q++=ScaleQuantumToLong(GetPixelGreen(image,p));
2010 *q++=ScaleQuantumToLong(GetPixelRed(image,p));
2016 if (LocaleCompare(stream_info->map,"I") == 0)
2018 p=GetVirtualPixelQueue(image);
2019 if (p == (const Quantum *) NULL)
2021 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2023 *q++=ScaleQuantumToLong(GetPixelIntensity(image,p));
2028 if (LocaleCompare(stream_info->map,"RGB") == 0)
2030 p=GetVirtualPixelQueue(image);
2031 if (p == (const Quantum *) NULL)
2033 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2035 *q++=ScaleQuantumToLong(GetPixelRed(image,p));
2036 *q++=ScaleQuantumToLong(GetPixelGreen(image,p));
2037 *q++=ScaleQuantumToLong(GetPixelBlue(image,p));
2042 if (LocaleCompare(stream_info->map,"RGBA") == 0)
2044 p=GetVirtualPixelQueue(image);
2045 if (p == (const Quantum *) NULL)
2047 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2049 *q++=ScaleQuantumToLong(GetPixelRed(image,p));
2050 *q++=ScaleQuantumToLong(GetPixelGreen(image,p));
2051 *q++=ScaleQuantumToLong(GetPixelBlue(image,p));
2052 *q++=ScaleQuantumToLong((Quantum) (GetPixelAlpha(image,p)));
2057 if (LocaleCompare(stream_info->map,"RGBP") == 0)
2059 p=GetVirtualPixelQueue(image);
2060 if (p == (const Quantum *) NULL)
2062 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2064 *q++=ScaleQuantumToLong(GetPixelRed(image,p));
2065 *q++=ScaleQuantumToLong(GetPixelGreen(image,p));
2066 *q++=ScaleQuantumToLong(GetPixelBlue(image,p));
2072 p=GetVirtualPixelQueue(image);
2073 if (p == (const Quantum *) NULL)
2075 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2077 for (i=0; i < (ssize_t) length; i++)
2080 switch (quantum_map[i])
2085 *q=ScaleQuantumToLong(GetPixelRed(image,p));
2089 case MagentaQuantum:
2091 *q=ScaleQuantumToLong(GetPixelGreen(image,p));
2097 *q=ScaleQuantumToLong(GetPixelBlue(image,p));
2102 *q=ScaleQuantumToLong((Quantum) (GetPixelAlpha(image,p)));
2105 case OpacityQuantum:
2107 *q=ScaleQuantumToLong(GetPixelAlpha(image,p));
2112 if (image->colorspace == CMYKColorspace)
2113 *q=ScaleQuantumToLong(GetPixelBlack(image,p));
2118 *q=ScaleQuantumToLong(GetPixelIntensity(image,p));
2132 register MagickSizeType
2135 q=(MagickSizeType *) stream_info->pixels;
2136 if (LocaleCompare(stream_info->map,"BGR") == 0)
2138 p=GetVirtualPixelQueue(image);
2139 if (p == (const Quantum *) NULL)
2141 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2143 *q++=ScaleQuantumToLongLong(GetPixelBlue(image,p));
2144 *q++=ScaleQuantumToLongLong(GetPixelGreen(image,p));
2145 *q++=ScaleQuantumToLongLong(GetPixelRed(image,p));
2150 if (LocaleCompare(stream_info->map,"BGRA") == 0)
2152 p=GetVirtualPixelQueue(image);
2153 if (p == (const Quantum *) NULL)
2155 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2157 *q++=ScaleQuantumToLongLong(GetPixelBlue(image,p));
2158 *q++=ScaleQuantumToLongLong(GetPixelGreen(image,p));
2159 *q++=ScaleQuantumToLongLong(GetPixelRed(image,p));
2160 *q++=ScaleQuantumToLongLong(GetPixelAlpha(image,p));
2165 if (LocaleCompare(stream_info->map,"BGRP") == 0)
2167 p=GetVirtualPixelQueue(image);
2168 if (p == (const Quantum *) NULL)
2170 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2172 *q++=ScaleQuantumToLongLong(GetPixelBlue(image,p));
2173 *q++=ScaleQuantumToLongLong(GetPixelGreen(image,p));
2174 *q++=ScaleQuantumToLongLong(GetPixelRed(image,p));
2180 if (LocaleCompare(stream_info->map,"I") == 0)
2182 p=GetVirtualPixelQueue(image);
2183 if (p == (const Quantum *) NULL)
2185 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2187 *q++=ScaleQuantumToLongLong(
2188 GetPixelIntensity(image,p));
2193 if (LocaleCompare(stream_info->map,"RGB") == 0)
2195 p=GetVirtualPixelQueue(image);
2196 if (p == (const Quantum *) NULL)
2198 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2200 *q++=ScaleQuantumToLongLong(GetPixelRed(image,p));
2201 *q++=ScaleQuantumToLongLong(GetPixelGreen(image,p));
2202 *q++=ScaleQuantumToLongLong(GetPixelBlue(image,p));
2207 if (LocaleCompare(stream_info->map,"RGBA") == 0)
2209 p=GetVirtualPixelQueue(image);
2210 if (p == (const Quantum *) NULL)
2212 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2214 *q++=ScaleQuantumToLongLong(GetPixelRed(image,p));
2215 *q++=ScaleQuantumToLongLong(GetPixelGreen(image,p));
2216 *q++=ScaleQuantumToLongLong(GetPixelBlue(image,p));
2217 *q++=ScaleQuantumToLongLong(GetPixelAlpha(image,p));
2222 if (LocaleCompare(stream_info->map,"RGBP") == 0)
2224 p=GetVirtualPixelQueue(image);
2225 if (p == (const Quantum *) NULL)
2227 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2229 *q++=ScaleQuantumToLongLong(GetPixelRed(image,p));
2230 *q++=ScaleQuantumToLongLong(GetPixelGreen(image,p));
2231 *q++=ScaleQuantumToLongLong(GetPixelBlue(image,p));
2237 p=GetVirtualPixelQueue(image);
2238 if (p == (const Quantum *) NULL)
2240 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2242 for (i=0; i < (ssize_t) length; i++)
2245 switch (quantum_map[i])
2250 *q=ScaleQuantumToLongLong(GetPixelRed(image,p));
2254 case MagentaQuantum:
2256 *q=ScaleQuantumToLongLong(GetPixelGreen(image,p));
2262 *q=ScaleQuantumToLongLong(GetPixelBlue(image,p));
2267 *q=ScaleQuantumToLongLong(GetPixelAlpha(image,p));
2270 case OpacityQuantum:
2272 *q=ScaleQuantumToLongLong(GetPixelAlpha(image,p));
2277 if (image->colorspace == CMYKColorspace)
2278 *q=ScaleQuantumToLongLong(GetPixelBlack(image,p));
2283 *q=ScaleQuantumToLongLong(GetPixelIntensity(image,p));
2300 q=(Quantum *) stream_info->pixels;
2301 if (LocaleCompare(stream_info->map,"BGR") == 0)
2303 p=GetVirtualPixelQueue(image);
2304 if (p == (const Quantum *) NULL)
2306 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2308 *q++=GetPixelBlue(image,p);
2309 *q++=GetPixelGreen(image,p);
2310 *q++=GetPixelRed(image,p);
2315 if (LocaleCompare(stream_info->map,"BGRA") == 0)
2317 p=GetVirtualPixelQueue(image);
2318 if (p == (const Quantum *) NULL)
2320 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2322 *q++=GetPixelBlue(image,p);
2323 *q++=GetPixelGreen(image,p);
2324 *q++=GetPixelRed(image,p);
2325 *q++=GetPixelAlpha(image,p);
2330 if (LocaleCompare(stream_info->map,"BGRP") == 0)
2332 p=GetVirtualPixelQueue(image);
2333 if (p == (const Quantum *) NULL)
2335 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2337 *q++=GetPixelBlue(image,p);
2338 *q++=GetPixelGreen(image,p);
2339 *q++=GetPixelRed(image,p);
2345 if (LocaleCompare(stream_info->map,"I") == 0)
2347 p=GetVirtualPixelQueue(image);
2348 if (p == (const Quantum *) NULL)
2350 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2352 *q++=GetPixelIntensity(image,p);
2357 if (LocaleCompare(stream_info->map,"RGB") == 0)
2359 p=GetVirtualPixelQueue(image);
2360 if (p == (const Quantum *) NULL)
2362 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2364 *q++=GetPixelRed(image,p);
2365 *q++=GetPixelGreen(image,p);
2366 *q++=GetPixelBlue(image,p);
2371 if (LocaleCompare(stream_info->map,"RGBA") == 0)
2373 p=GetVirtualPixelQueue(image);
2374 if (p == (const Quantum *) NULL)
2376 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2378 *q++=GetPixelRed(image,p);
2379 *q++=GetPixelGreen(image,p);
2380 *q++=GetPixelBlue(image,p);
2381 *q++=GetPixelAlpha(image,p);
2386 if (LocaleCompare(stream_info->map,"RGBP") == 0)
2388 p=GetVirtualPixelQueue(image);
2389 if (p == (const Quantum *) NULL)
2391 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2393 *q++=GetPixelRed(image,p);
2394 *q++=GetPixelGreen(image,p);
2395 *q++=GetPixelBlue(image,p);
2401 p=GetVirtualPixelQueue(image);
2402 if (p == (const Quantum *) NULL)
2404 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2406 for (i=0; i < (ssize_t) length; i++)
2409 switch (quantum_map[i])
2414 *q=GetPixelRed(image,p);
2418 case MagentaQuantum:
2420 *q=GetPixelGreen(image,p);
2426 *q=GetPixelBlue(image,p);
2431 *q=(Quantum) (GetPixelAlpha(image,p));
2434 case OpacityQuantum:
2436 *q=GetPixelAlpha(image,p);
2441 if (image->colorspace == CMYKColorspace)
2442 *q=GetPixelBlack(image,p);
2447 *q=GetPixelIntensity(image,p);
2461 register unsigned short
2464 q=(unsigned short *) stream_info->pixels;
2465 if (LocaleCompare(stream_info->map,"BGR") == 0)
2467 p=GetVirtualPixelQueue(image);
2468 if (p == (const Quantum *) NULL)
2470 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2472 *q++=ScaleQuantumToShort(GetPixelBlue(image,p));
2473 *q++=ScaleQuantumToShort(GetPixelGreen(image,p));
2474 *q++=ScaleQuantumToShort(GetPixelRed(image,p));
2479 if (LocaleCompare(stream_info->map,"BGRA") == 0)
2481 p=GetVirtualPixelQueue(image);
2482 if (p == (const Quantum *) NULL)
2484 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2486 *q++=ScaleQuantumToShort(GetPixelBlue(image,p));
2487 *q++=ScaleQuantumToShort(GetPixelGreen(image,p));
2488 *q++=ScaleQuantumToShort(GetPixelRed(image,p));
2489 *q++=ScaleQuantumToShort((Quantum) (GetPixelAlpha(image,p)));
2494 if (LocaleCompare(stream_info->map,"BGRP") == 0)
2496 p=GetVirtualPixelQueue(image);
2497 if (p == (const Quantum *) NULL)
2499 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2501 *q++=ScaleQuantumToShort(GetPixelBlue(image,p));
2502 *q++=ScaleQuantumToShort(GetPixelGreen(image,p));
2503 *q++=ScaleQuantumToShort(GetPixelRed(image,p));
2509 if (LocaleCompare(stream_info->map,"I") == 0)
2511 p=GetVirtualPixelQueue(image);
2512 if (p == (const Quantum *) NULL)
2514 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2516 *q++=ScaleQuantumToShort(GetPixelIntensity(image,p));
2521 if (LocaleCompare(stream_info->map,"RGB") == 0)
2523 p=GetVirtualPixelQueue(image);
2524 if (p == (const Quantum *) NULL)
2526 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2528 *q++=ScaleQuantumToShort(GetPixelRed(image,p));
2529 *q++=ScaleQuantumToShort(GetPixelGreen(image,p));
2530 *q++=ScaleQuantumToShort(GetPixelBlue(image,p));
2535 if (LocaleCompare(stream_info->map,"RGBA") == 0)
2537 p=GetVirtualPixelQueue(image);
2538 if (p == (const Quantum *) NULL)
2540 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2542 *q++=ScaleQuantumToShort(GetPixelRed(image,p));
2543 *q++=ScaleQuantumToShort(GetPixelGreen(image,p));
2544 *q++=ScaleQuantumToShort(GetPixelBlue(image,p));
2545 *q++=ScaleQuantumToShort((Quantum) (GetPixelAlpha(image,p)));
2550 if (LocaleCompare(stream_info->map,"RGBP") == 0)
2552 p=GetVirtualPixelQueue(image);
2553 if (p == (const Quantum *) NULL)
2555 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2557 *q++=ScaleQuantumToShort(GetPixelRed(image,p));
2558 *q++=ScaleQuantumToShort(GetPixelGreen(image,p));
2559 *q++=ScaleQuantumToShort(GetPixelBlue(image,p));
2565 p=GetVirtualPixelQueue(image);
2566 if (p == (const Quantum *) NULL)
2568 for (x=0; x < (ssize_t) GetImageExtent(image); x++)
2570 for (i=0; i < (ssize_t) length; i++)
2573 switch (quantum_map[i])
2578 *q=ScaleQuantumToShort(GetPixelRed(image,p));
2582 case MagentaQuantum:
2584 *q=ScaleQuantumToShort(GetPixelGreen(image,p));
2590 *q=ScaleQuantumToShort(GetPixelBlue(image,p));
2595 *q=ScaleQuantumToShort(GetPixelAlpha(image,p));
2598 case OpacityQuantum:
2600 *q=ScaleQuantumToShort(GetPixelAlpha(image,p));
2605 if (image->colorspace == CMYKColorspace)
2606 *q=ScaleQuantumToShort(GetPixelBlack(image,p));
2611 *q=ScaleQuantumToShort(GetPixelIntensity(image,p));
2625 quantum_map=(QuantumType *) RelinquishMagickMemory(quantum_map);
2626 (void) ThrowMagickException(exception,GetMagickModule(),OptionError,
2627 "UnrecognizedPixelMap","'%s'",stream_info->map);
2631 quantum_map=(QuantumType *) RelinquishMagickMemory(quantum_map);
2636 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2640 + S y n c A u t h e n t i c P i x e l s S t r e a m %
2644 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2646 % SyncAuthenticPixelsStream() calls the user supplied callback method with
2647 % the latest stream of pixels.
2649 % The format of the SyncAuthenticPixelsStream method is:
2651 % MagickBooleanType SyncAuthenticPixelsStream(Image *image,
2652 % ExceptionInfo *exception)
2654 % A description of each parameter follows:
2656 % o image: the image.
2658 % o exception: return any errors or warnings in this structure.
2661 static MagickBooleanType SyncAuthenticPixelsStream(Image *image,
2662 ExceptionInfo *exception)
2673 assert(image != (Image *) NULL);
2674 assert(image->signature == MagickSignature);
2675 if (image->debug != MagickFalse)
2676 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",image->filename);
2677 cache_info=(CacheInfo *) image->cache;
2678 assert(cache_info->signature == MagickSignature);
2679 stream_handler=GetBlobStreamHandler(image);
2680 if (stream_handler == (StreamHandler) NULL)
2682 (void) ThrowMagickException(exception,GetMagickModule(),StreamError,
2683 "NoStreamHandlerIsDefined","'%s'",image->filename);
2684 return(MagickFalse);
2686 length=stream_handler(image,cache_info->pixels,(size_t) cache_info->columns);
2687 return(length == cache_info->columns ? MagickTrue : MagickFalse);
2691 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2695 % W r i t e S t r e a m %
2699 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2701 % WriteStream() makes the image pixels available to a user supplied callback
2702 % method immediately upon writing pixel data with the WriteImage() method.
2704 % The format of the WriteStream() method is:
2706 % MagickBooleanType WriteStream(const ImageInfo *image_info,Image *,
2707 % StreamHandler stream,ExceptionInfo *exception)
2709 % A description of each parameter follows:
2711 % o image_info: the image info.
2713 % o stream: A callback method.
2715 % o exception: return any errors or warnings in this structure.
2718 MagickExport MagickBooleanType WriteStream(const ImageInfo *image_info,
2719 Image *image,StreamHandler stream,ExceptionInfo *exception)
2727 assert(image_info != (ImageInfo *) NULL);
2728 assert(image_info->signature == MagickSignature);
2729 if (image_info->debug != MagickFalse)
2730 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",
2731 image_info->filename);
2732 assert(image != (Image *) NULL);
2733 assert(image->signature == MagickSignature);
2734 write_info=CloneImageInfo(image_info);
2735 write_info->stream=stream;
2736 status=WriteImage(write_info,image,exception);
2737 write_info=DestroyImageInfo(write_info);