2 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
6 % CCCC OOO M M PPPP OOO SSSSS IIIII TTTTT EEEEE %
7 % C O O MM MM P P O O SS I T E %
8 % C O O M M M PPPP O O SSS I T EEE %
9 % C O O M M P O O SS I T E %
10 % CCCC OOO M M P OOO SSSSS IIIII T EEEEE %
13 % MagickWand Image Composite Methods %
20 % Copyright 1999-2009 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 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
36 % Use the composite program to overlap one image over another.
43 #include "wand/studio.h"
44 #include "wand/MagickWand.h"
45 #include "wand/mogrify-private.h"
50 typedef struct _CompositeOptions
77 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
81 % C o m p o s i t e I m a g e C o m m a n d %
85 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
87 % CompositeImageCommand() reads one or more images and an optional mask and
88 % composites them into a new image.
90 % The format of the CompositeImageCommand method is:
92 % MagickBooleanType CompositeImageCommand(ImageInfo *image_info,int argc,
93 % char **argv,char **metadata,ExceptionInfo *exception)
95 % A description of each parameter follows:
97 % o image_info: the image info.
99 % o argc: the number of elements in the argument vector.
101 % o argv: A text array containing the command line arguments.
103 % o metadata: any metadata is returned here.
105 % o exception: return any errors or warnings in this structure.
109 static MagickBooleanType CompositeImageList(ImageInfo *image_info,Image **image,
110 Image *composite_image,CompositeOptions *composite_options,
111 ExceptionInfo *exception)
116 assert(image_info != (ImageInfo *) NULL);
117 assert(image_info->signature == MagickSignature);
118 assert(image != (Image **) NULL);
119 assert((*image)->signature == MagickSignature);
120 if ((*image)->debug != MagickFalse)
121 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",(*image)->filename);
122 assert(exception != (ExceptionInfo *) NULL);
124 if (composite_image != (Image *) NULL)
126 assert(composite_image->signature == MagickSignature);
127 switch( composite_options->compose )
129 case BlendCompositeOp:
130 case BlurCompositeOp:
131 case DisplaceCompositeOp:
132 case DistortCompositeOp:
133 case DissolveCompositeOp:
134 case ModulateCompositeOp:
135 case ThresholdCompositeOp:
136 (void) SetImageArtifact(composite_image,"compose:args",
137 composite_options->compose_args);
145 if (composite_options->stegano != 0)
150 (*image)->offset=composite_options->stegano-1;
151 stegano_image=SteganoImage(*image,composite_image,exception);
152 if (stegano_image != (Image *) NULL)
154 *image=DestroyImageList(*image);
155 *image=stegano_image;
159 if (composite_options->stereo != MagickFalse)
164 stereo_image=StereoAnaglyphImage(*image,composite_image,
165 composite_options->offset.x,composite_options->offset.y,
167 if (stereo_image != (Image *) NULL)
169 *image=DestroyImageList(*image);
174 if (composite_options->tile != MagickFalse)
184 Tile the composite image.
186 (void) SetImageArtifact(composite_image,"compose:outside-overlay",
188 columns=composite_image->columns;
189 for (y=0; y < (long) (*image)->rows; y+=composite_image->rows)
190 for (x=0; x < (long) (*image)->columns; x+=columns)
191 status&=CompositeImageChannel(*image,
192 composite_options->channel,composite_options->compose,
193 composite_image,x,y);
194 GetImageException(*image,exception);
202 Work out gravity Adjustment of Offset
204 SetGeometry(*image,&geometry);
205 (void) ParseAbsoluteGeometry(composite_options->geometry,
207 geometry.width=composite_image->columns;
208 geometry.height=composite_image->rows;
209 GravityAdjustGeometry((*image)->columns,(*image)->rows,
210 composite_options->gravity, &geometry);
211 (*image)->gravity=(GravityType) composite_options->gravity;
213 Digitally composite image.
215 status&=CompositeImageChannel(*image,composite_options->channel,
216 composite_options->compose,composite_image,geometry.x,
218 GetImageException(*image,exception);
221 return(status != 0 ? MagickTrue : MagickFalse);
224 static MagickBooleanType CompositeUsage(void)
232 "-debug events display copious debugging information",
233 "-help print program options",
234 "-list type print a list of supported option arguments",
235 "-log format format of debugging information",
236 "-version print version information",
241 "-blend geometry blend images",
242 "-border geometry surround image with a border of color",
243 "-bordercolor color border color",
244 "-colors value preferred number of colors in the image",
245 "-decipher filename convert cipher pixels to plain pixels",
246 "-displace geometry shift lookup according to a relative displacement map",
247 "-dissolve value dissolve the two images a given percent",
248 "-distort geometry shift lookup according to a absolute distortion map",
249 "-encipher filename convert plain pixels to cipher pixels",
250 "-extract geometry extract area from image",
251 "-geometry geometry location of the composite image",
252 "-identify identify the format and characteristics of the image",
253 "-monochrome transform image to black and white",
254 "-negate replace every pixel with its complementary color ",
255 "-profile filename add ICM or IPTC information profile to image",
256 "-quantize colorspace reduce colors in this colorspace",
257 "-repage geometry size and location of an image canvas (operator)",
258 "-rotate degrees apply Paeth rotation to the image",
259 "-resize geometry resize the image",
260 "-sharpen geometry sharpen the image",
261 "-shave geometry shave pixels from the image edges",
262 "-stegano offset hide watermark within an image",
263 "-stereo geometry combine two image to create a stereo anaglyph",
264 "-strip strip image of all profiles and comments",
265 "-thumbnail geometry create a thumbnail of the image",
266 "-transform affine transform image",
267 "-type type image type",
268 "-unsharp geometry sharpen the image",
269 "-watermark geometry percent brightness and saturation of a watermark",
270 "-write filename write images to this file",
275 "-affine matrix affine transform matrix",
276 "-alpha option on, activate, off, deactivate, set, opaque, copy",
277 " transparent, extract, background, or shape",
278 "-authenticate password",
279 " decipher image with this password",
280 "-blue-primary point chromaticity blue primary point",
281 "-channel type apply option to select image channels",
282 "-colorspace type alternate image colorspace",
283 "-comment string annotate image with comment",
284 "-compose operator composite operator",
285 "-compress type type of pixel compression when writing the image",
286 "-define format:option",
287 " define one or more image format options",
288 "-depth value image depth",
289 "-density geometry horizontal and vertical density of the image",
290 "-display server get image or font from this X server",
291 "-dispose method layer disposal method",
292 "-dither method apply error diffusion to image",
293 "-encoding type text encoding type",
294 "-endian type endianness (MSB or LSB) of the image",
295 "-filter type use this filter when resizing an image",
296 "-font name render text with this font",
297 "-format \"string\" output formatted image characteristics",
298 "-gravity type which direction to gravitate towards",
299 "-green-primary point chromaticity green primary point",
300 "-interlace type type of image interlacing scheme",
301 "-interpolate method pixel color interpolation method",
302 "-label string assign a label to an image",
303 "-limit type value pixel cache resource limit",
304 "-monitor monitor progress",
305 "-page geometry size and location of an image canvas (setting)",
306 "-pointsize value font point size",
307 "-quality value JPEG/MIFF/PNG compression level",
308 "-quiet suppress all warning messages",
309 "-red-primary point chromaticity red primary point",
310 "-regard-warnings pay attention to warning messages",
311 "-respect-parentheses settings remain in effect until parenthesis boundary",
312 "-sampling-factor geometry",
313 " horizontal and vertical sampling factor",
314 "-scene value image scene number",
315 "-seed value seed a new sequence of pseudo-random numbers",
316 "-size geometry width and height of image",
317 "-transparent-color color",
318 " transparent color",
319 "-treedepth value color tree depth",
320 "-tile repeat composite operation across and down image",
321 "-units type the units of image resolution",
322 "-verbose print detailed information about the image",
323 "-virtual-pixel method",
324 " virtual pixel access method",
325 "-white-point point chromaticity white point",
330 "-swap indexes swap two images in the image sequence",
335 (void) printf("Version: %s\n",GetMagickVersion((unsigned long *) NULL));
336 (void) printf("Copyright: %s\n",GetMagickCopyright());
337 (void) printf("Features: %s\n\n",GetMagickFeatures());
338 (void) printf("Usage: %s [options ...] image [options ...] composite\n"
339 " [ [options ...] mask ] [options ...] composite\n",
341 (void) printf("\nImage Settings:\n");
342 for (p=settings; *p != (char *) NULL; p++)
343 (void) printf(" %s\n",*p);
344 (void) printf("\nImage Operators:\n");
345 for (p=operators; *p != (char *) NULL; p++)
346 (void) printf(" %s\n",*p);
347 (void) printf("\nImage Stack Operators:\n");
348 for (p=stack_operators; *p != (char *) NULL; p++)
349 (void) printf(" %s\n",*p);
350 (void) printf("\nMiscellaneous Options:\n");
351 for (p=miscellaneous; *p != (char *) NULL; p++)
352 (void) printf(" %s\n",*p);
354 "\nBy default, the image format of `file' is determined by its magic\n");
356 "number. To specify a particular image format, precede the filename\n");
358 "with an image format name and a colon (i.e. ps:image) or specify the\n");
360 "image type as the filename suffix (i.e. image.ps). Specify 'file' as\n");
361 (void) printf("'-' for standard input or output.\n");
365 static void GetCompositeOptions(CompositeOptions *composite_options)
367 (void) ResetMagickMemory(composite_options,0,sizeof(*composite_options));
368 composite_options->channel=DefaultChannels;
369 composite_options->compose=OverCompositeOp;
372 static void RelinquishCompositeOptions(CompositeOptions *composite_options)
374 if (composite_options->compose_args != (char *) NULL)
375 composite_options->compose_args=(char *)
376 RelinquishMagickMemory(composite_options->compose_args);
379 WandExport MagickBooleanType CompositeImageCommand(ImageInfo *image_info,
380 int argc,char **argv,char **metadata,ExceptionInfo *exception)
382 #define NotInitialized (unsigned int) (~0)
383 #define DestroyComposite() \
385 RelinquishCompositeOptions(&composite_options); \
386 DestroyImageStack(); \
387 for (i=0; i < (long) argc; i++) \
388 argv[i]=DestroyString(argv[i]); \
389 argv=(char **) RelinquishMagickMemory(argv); \
391 #define ThrowCompositeException(asperity,tag,option) \
393 (void) ThrowMagickException(exception,GetMagickModule(),asperity,tag,"`%s'", \
394 option == (char *) NULL ? GetExceptionMessage(errno) : option); \
395 DestroyComposite(); \
396 return(MagickFalse); \
398 #define ThrowCompositeInvalidArgumentException(option,argument) \
400 (void) ThrowMagickException(exception,GetMagickModule(),OptionError, \
401 "InvalidArgument","`%s': %s",option,argument); \
402 DestroyComposite(); \
403 return(MagickFalse); \
423 image_stack[MaxImageStackDepth+1];
442 assert(image_info != (ImageInfo *) NULL);
443 assert(image_info->signature == MagickSignature);
444 if (image_info->debug != MagickFalse)
445 (void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
446 assert(exception != (ExceptionInfo *) NULL);
450 if ((LocaleCompare("version",option+1) == 0) ||
451 (LocaleCompare("-version",option+1) == 0))
453 (void) fprintf(stdout,"Version: %s\n",
454 GetMagickVersion((unsigned long *) NULL));
455 (void) fprintf(stdout,"Copyright: %s\n",GetMagickCopyright());
456 (void) fprintf(stdout,"Features: %s\n\n",GetMagickFeatures());
462 (void) CompositeUsage();
465 GetCompositeOptions(&composite_options);
466 filename=(char *) NULL;
471 option=(char *) NULL;
475 Check command syntax.
477 composite_image=NewImageList();
478 image=NewImageList();
479 mask_image=NewImageList();
480 ReadCommandlLine(argc,&argv);
481 status=ExpandFilenames(&argc,&argv);
482 if (status == MagickFalse)
483 ThrowCompositeException(ResourceLimitError,"MemoryAllocationFailed",
484 GetExceptionMessage(errno));
485 for (i=1; i < (long) (argc-1); i++)
488 if (LocaleCompare(option,"(") == 0)
490 FireImageStack(MagickFalse,MagickTrue,pend);
491 if (k == MaxImageStackDepth)
492 ThrowCompositeException(OptionError,"ParenthesisNestedTooDeeply",
497 if (LocaleCompare(option,")") == 0)
499 FireImageStack(MagickFalse,MagickTrue,MagickTrue);
501 ThrowCompositeException(OptionError,"UnableToParseExpression",option);
505 if (IsMagickOption(option) == MagickFalse)
513 FireImageStack(MagickFalse,MagickFalse,pend);
515 if ((LocaleCompare(filename,"--") == 0) && (i < (argc-1)))
517 (void) CopyMagickString(image_info->filename,filename,MaxTextExtent);
518 images=ReadImages(image_info,exception);
519 status&=(images != (Image *) NULL) &&
520 (exception->severity < ErrorException);
521 if (images == (Image *) NULL)
523 AppendImageStack(images);
526 pend=image != (Image *) NULL ? MagickTrue : MagickFalse;
531 if (LocaleCompare("affine",option+1) == 0)
536 if (i == (long) argc)
537 ThrowCompositeException(OptionError,"MissingArgument",option);
538 if (IsGeometry(argv[i]) == MagickFalse)
539 ThrowCompositeInvalidArgumentException(option,argv[i]);
542 if (LocaleCompare("alpha",option+1) == 0)
550 if (i == (long) argc)
551 ThrowCompositeException(OptionError,"MissingArgument",option);
552 type=ParseMagickOption(MagickAlphaOptions,MagickFalse,argv[i]);
554 ThrowCompositeException(OptionError,
555 "UnrecognizedAlphaChannelType",argv[i]);
558 if (LocaleCompare("authenticate",option+1) == 0)
563 if (i == (long) argc)
564 ThrowCompositeException(OptionError,"MissingArgument",option);
567 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
571 if (LocaleCompare("background",option+1) == 0)
576 if (i == (long) argc)
577 ThrowCompositeException(OptionError,"MissingArgument",option);
580 if (LocaleCompare("blend",option+1) == 0)
582 (void) CloneString(&composite_options.compose_args,(char *) NULL);
586 if (i == (long) argc)
587 ThrowCompositeException(OptionError,"MissingArgument",option);
588 if (IsGeometry(argv[i]) == MagickFalse)
589 ThrowCompositeInvalidArgumentException(option,argv[i]);
590 (void) CloneString(&composite_options.compose_args,argv[i]);
591 composite_options.compose=BlendCompositeOp;
594 if (LocaleCompare("blur",option+1) == 0)
596 (void) CloneString(&composite_options.compose_args,(char *) NULL);
600 if (i == (long) argc)
601 ThrowCompositeException(OptionError,"MissingArgument",option);
602 if (IsGeometry(argv[i]) == MagickFalse)
603 ThrowCompositeInvalidArgumentException(option,argv[i]);
604 (void) CloneString(&composite_options.compose_args,argv[i]);
605 composite_options.compose=BlurCompositeOp;
608 if (LocaleCompare("blue-primary",option+1) == 0)
613 if (i == (long) argc)
614 ThrowCompositeException(OptionError,"MissingArgument",option);
615 if (IsGeometry(argv[i]) == MagickFalse)
616 ThrowCompositeInvalidArgumentException(option,argv[i]);
619 if (LocaleCompare("border",option+1) == 0)
624 if (i == (long) (argc-1))
625 ThrowCompositeException(OptionError,"MissingArgument",option);
626 if (IsGeometry(argv[i]) == MagickFalse)
627 ThrowCompositeInvalidArgumentException(option,argv[i]);
630 if (LocaleCompare("bordercolor",option+1) == 0)
635 if (i == (long) (argc-1))
636 ThrowCompositeException(OptionError,"MissingArgument",option);
639 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
643 if (LocaleCompare("cache",option+1) == 0)
648 if (i == (long) argc)
649 ThrowCompositeException(OptionError,"MissingArgument",option);
650 if (IsGeometry(argv[i]) == MagickFalse)
651 ThrowCompositeInvalidArgumentException(option,argv[i]);
654 if (LocaleCompare("channel",option+1) == 0)
661 composite_options.channel=DefaultChannels;
665 if (i == (long) (argc-1))
666 ThrowCompositeException(OptionError,"MissingArgument",option);
667 channel=ParseChannelOption(argv[i]);
669 ThrowCompositeException(OptionError,"UnrecognizedChannelType",
671 composite_options.channel=(ChannelType) channel;
674 if (LocaleCompare("colors",option+1) == 0)
679 if (i == (long) argc)
680 ThrowCompositeException(OptionError,"MissingArgument",option);
681 if (IsGeometry(argv[i]) == MagickFalse)
682 ThrowCompositeInvalidArgumentException(option,argv[i]);
685 if (LocaleCompare("colorspace",option+1) == 0)
693 if (i == (long) argc)
694 ThrowCompositeException(OptionError,"MissingArgument",option);
695 colorspace=ParseMagickOption(MagickColorspaceOptions,
696 MagickFalse,argv[i]);
698 ThrowCompositeException(OptionError,"UnrecognizedColorspace",
702 if (LocaleCompare("comment",option+1) == 0)
707 if (i == (long) argc)
708 ThrowCompositeException(OptionError,"MissingArgument",option);
711 if (LocaleCompare("compose",option+1) == 0)
716 composite_options.compose=UndefinedCompositeOp;
720 if (i == (long) argc)
721 ThrowCompositeException(OptionError,"MissingArgument",option);
722 compose=ParseMagickOption(MagickComposeOptions,MagickFalse,
725 ThrowCompositeException(OptionError,"UnrecognizedComposeOperator",
727 composite_options.compose=(CompositeOperator) compose;
730 if (LocaleCompare("compress",option+1) == 0)
738 if (i == (long) argc)
739 ThrowCompositeException(OptionError,"MissingArgument",option);
740 compress=ParseMagickOption(MagickCompressOptions,MagickFalse,
743 ThrowCompositeException(OptionError,
744 "UnrecognizedImageCompression",argv[i]);
747 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
751 if (LocaleCompare("debug",option+1) == 0)
759 if (i == (long) argc)
760 ThrowCompositeException(OptionError,"MissingArgument",option);
761 event=ParseMagickOption(MagickLogEventOptions,MagickFalse,argv[i]);
763 ThrowCompositeException(OptionError,"UnrecognizedEventType",
765 (void) SetLogEventMask(argv[i]);
768 if (LocaleCompare("decipher",option+1) == 0)
773 if (i == (long) (argc-1))
774 ThrowCompositeException(OptionError,"MissingArgument",option);
777 if (LocaleCompare("define",option+1) == 0)
780 if (i == (long) argc)
781 ThrowCompositeException(OptionError,"MissingArgument",option);
787 define=GetImageOption(image_info,argv[i]);
788 if (define == (const char *) NULL)
789 ThrowCompositeException(OptionError,"NoSuchOption",argv[i]);
794 if (LocaleCompare("density",option+1) == 0)
799 if (i == (long) argc)
800 ThrowCompositeException(OptionError,"MissingArgument",option);
801 if (IsGeometry(argv[i]) == MagickFalse)
802 ThrowCompositeInvalidArgumentException(option,argv[i]);
805 if (LocaleCompare("depth",option+1) == 0)
810 if (i == (long) argc)
811 ThrowCompositeException(OptionError,"MissingArgument",option);
812 if (IsGeometry(argv[i]) == MagickFalse)
813 ThrowCompositeInvalidArgumentException(option,argv[i]);
816 if (LocaleCompare("displace",option+1) == 0)
818 (void) CloneString(&composite_options.compose_args,(char *) NULL);
822 if (i == (long) argc)
823 ThrowCompositeException(OptionError,"MissingArgument",option);
824 if (IsGeometry(argv[i]) == MagickFalse)
825 ThrowCompositeInvalidArgumentException(option,argv[i]);
826 (void) CloneString(&composite_options.compose_args,argv[i]);
827 composite_options.compose=DisplaceCompositeOp;
830 if (LocaleCompare("display",option+1) == 0)
835 if (i == (long) argc)
836 ThrowCompositeException(OptionError,"MissingArgument",option);
839 if (LocaleCompare("dispose",option+1) == 0)
847 if (i == (long) argc)
848 ThrowCompositeException(OptionError,"MissingArgument",option);
849 dispose=ParseMagickOption(MagickDisposeOptions,MagickFalse,argv[i]);
851 ThrowCompositeException(OptionError,"UnrecognizedDisposeMethod",
855 if (LocaleCompare("dissolve",option+1) == 0)
857 (void) CloneString(&composite_options.compose_args,(char *) NULL);
861 if (i == (long) argc)
862 ThrowCompositeException(OptionError,"MissingArgument",option);
863 if (IsGeometry(argv[i]) == MagickFalse)
864 ThrowCompositeInvalidArgumentException(option,argv[i]);
865 (void) CloneString(&composite_options.compose_args,argv[i]);
866 composite_options.compose=DissolveCompositeOp;
869 if (LocaleCompare("distort",option+1) == 0)
871 (void) CloneString(&composite_options.compose_args,(char *) NULL);
875 if (i == (long) argc)
876 ThrowCompositeException(OptionError,"MissingArgument",option);
877 if (IsGeometry(argv[i]) == MagickFalse)
878 ThrowCompositeInvalidArgumentException(option,argv[i]);
879 (void) CloneString(&composite_options.compose_args,argv[i]);
880 composite_options.compose=DistortCompositeOp;
883 if (LocaleCompare("method",option+1) == 0)
891 if (i == (long) argc)
892 ThrowCompositeException(OptionError,"MissingArgument",option);
893 method=ParseMagickOption(MagickDitherOptions,MagickFalse,argv[i]);
895 ThrowCompositeException(OptionError,"UnrecognizedDitherMethod",
899 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
903 if (LocaleCompare("encipher",option+1) == 0)
908 if (i == (long) (argc-1))
909 ThrowCompositeException(OptionError,"MissingArgument",option);
912 if (LocaleCompare("encoding",option+1) == 0)
917 if (i == (long) argc)
918 ThrowCompositeException(OptionError,"MissingArgument",option);
921 if (LocaleCompare("endian",option+1) == 0)
929 if (i == (long) argc)
930 ThrowCompositeException(OptionError,"MissingArgument",option);
931 endian=ParseMagickOption(MagickEndianOptions,MagickFalse,
934 ThrowCompositeException(OptionError,"UnrecognizedEndianType",
938 if (LocaleCompare("extract",option+1) == 0)
943 if (i == (long) argc)
944 ThrowCompositeException(OptionError,"MissingArgument",option);
945 if (IsGeometry(argv[i]) == MagickFalse)
946 ThrowCompositeInvalidArgumentException(option,argv[i]);
949 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
953 if (LocaleCompare("filter",option+1) == 0)
961 if (i == (long) argc)
962 ThrowCompositeException(OptionError,"MissingArgument",option);
963 filter=ParseMagickOption(MagickFilterOptions,MagickFalse,argv[i]);
965 ThrowCompositeException(OptionError,"UnrecognizedImageFilter",
969 if (LocaleCompare("font",option+1) == 0)
974 if (i == (long) argc)
975 ThrowCompositeException(OptionError,"MissingArgument",option);
978 if (LocaleCompare("format",option+1) == 0)
983 if (i == (long) argc)
984 ThrowCompositeException(OptionError,"MissingArgument",option);
988 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
992 if (LocaleCompare("geometry",option+1) == 0)
994 (void) CloneString(&composite_options.geometry,(char *) NULL);
998 if (i == (long) argc)
999 ThrowCompositeException(OptionError,"MissingArgument",option);
1000 if (IsGeometry(argv[i]) == MagickFalse)
1001 ThrowCompositeInvalidArgumentException(option,argv[i]);
1002 (void) CloneString(&composite_options.geometry,argv[i]);
1005 if (LocaleCompare("gravity",option+1) == 0)
1010 composite_options.gravity=UndefinedGravity;
1014 if (i == (long) argc)
1015 ThrowCompositeException(OptionError,"MissingArgument",option);
1016 gravity=ParseMagickOption(MagickGravityOptions,MagickFalse,
1019 ThrowCompositeException(OptionError,"UnrecognizedGravityType",
1021 composite_options.gravity=(GravityType) gravity;
1024 if (LocaleCompare("green-primary",option+1) == 0)
1029 if (i == (long) argc)
1030 ThrowCompositeException(OptionError,"MissingArgument",option);
1031 if (IsGeometry(argv[i]) == MagickFalse)
1032 ThrowCompositeInvalidArgumentException(option,argv[i]);
1035 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1039 if ((LocaleCompare("help",option+1) == 0) ||
1040 (LocaleCompare("-help",option+1) == 0))
1041 return(CompositeUsage());
1042 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1046 if (LocaleCompare("identify",option+1) == 0)
1048 if (LocaleCompare("interlace",option+1) == 0)
1056 if (i == (long) argc)
1057 ThrowCompositeException(OptionError,"MissingArgument",option);
1058 interlace=ParseMagickOption(MagickInterlaceOptions,MagickFalse,
1061 ThrowCompositeException(OptionError,
1062 "UnrecognizedInterlaceType",argv[i]);
1065 if (LocaleCompare("interpolate",option+1) == 0)
1073 if (i == (long) argc)
1074 ThrowCompositeException(OptionError,"MissingArgument",option);
1075 interpolate=ParseMagickOption(MagickInterpolateOptions,MagickFalse,
1077 if (interpolate < 0)
1078 ThrowCompositeException(OptionError,
1079 "UnrecognizedInterpolateMethod",argv[i]);
1082 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1086 if (LocaleCompare("label",option+1) == 0)
1091 if (i == (long) argc)
1092 ThrowCompositeException(OptionError,"MissingArgument",option);
1095 if (LocaleCompare("limit",option+1) == 0)
1109 if (i == (long) argc)
1110 ThrowCompositeException(OptionError,"MissingArgument",option);
1111 resource=ParseMagickOption(MagickResourceOptions,MagickFalse,
1114 ThrowCompositeException(OptionError,"UnrecognizedResourceType",
1117 if (i == (long) argc)
1118 ThrowCompositeException(OptionError,"MissingArgument",option);
1119 value=strtod(argv[i],&p);
1120 if ((p == argv[i]) && (LocaleCompare("unlimited",argv[i]) != 0))
1121 ThrowCompositeInvalidArgumentException(option,argv[i]);
1124 if (LocaleCompare("list",option+1) == 0)
1132 if (i == (long) argc)
1133 ThrowCompositeException(OptionError,"MissingArgument",option);
1134 list=ParseMagickOption(MagickListOptions,MagickFalse,argv[i]);
1136 ThrowCompositeException(OptionError,"UnrecognizedListType",
1138 (void) MogrifyImageInfo(image_info,(int) (i-j+1),(const char **)
1143 if (LocaleCompare("log",option+1) == 0)
1148 if ((i == (long) argc) || (strchr(argv[i],'%') == (char *) NULL))
1149 ThrowCompositeException(OptionError,"MissingArgument",option);
1152 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1156 if (LocaleCompare("matte",option+1) == 0)
1158 if (LocaleCompare("monitor",option+1) == 0)
1160 if (LocaleCompare("monochrome",option+1) == 0)
1162 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1166 if (LocaleCompare("negate",option+1) == 0)
1168 if (LocaleCompare("noop",option+1) == 0)
1170 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1174 if (LocaleCompare("page",option+1) == 0)
1179 if (i == (long) argc)
1180 ThrowCompositeException(OptionError,"MissingArgument",option);
1183 if (LocaleCompare("pointsize",option+1) == 0)
1188 if (i == (long) (argc-1))
1189 ThrowCompositeException(OptionError,"MissingArgument",option);
1190 if (IsGeometry(argv[i]) == MagickFalse)
1191 ThrowCompositeInvalidArgumentException(option,argv[i]);
1194 if (LocaleCompare("process",option+1) == 0)
1199 if (i == (long) argc)
1200 ThrowCompositeException(OptionError,"MissingArgument",option);
1203 if (LocaleCompare("profile",option+1) == 0)
1206 if (i == (long) argc)
1207 ThrowCompositeException(OptionError,"MissingArgument",option);
1210 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1214 if (LocaleCompare("quality",option+1) == 0)
1219 if (i == (long) argc)
1220 ThrowCompositeException(OptionError,"MissingArgument",option);
1221 if (IsGeometry(argv[i]) == MagickFalse)
1222 ThrowCompositeInvalidArgumentException(option,argv[i]);
1225 if (LocaleCompare("quantize",option+1) == 0)
1233 if (i == (long) (argc-1))
1234 ThrowCompositeException(OptionError,"MissingArgument",option);
1235 colorspace=ParseMagickOption(MagickColorspaceOptions,
1236 MagickFalse,argv[i]);
1238 ThrowCompositeException(OptionError,"UnrecognizedColorspace",
1242 if (LocaleCompare("quiet",option+1) == 0)
1244 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1248 if (LocaleCompare("red-primary",option+1) == 0)
1253 if (i == (long) argc)
1254 ThrowCompositeException(OptionError,"MissingArgument",option);
1255 if (IsGeometry(argv[i]) == MagickFalse)
1256 ThrowCompositeInvalidArgumentException(option,argv[i]);
1259 if (LocaleCompare("regard-warnings",option+1) == 0)
1261 if (LocaleCompare("render",option+1) == 0)
1263 if (LocaleCompare("repage",option+1) == 0)
1268 if (i == (long) argc)
1269 ThrowCompositeException(OptionError,"MissingArgument",option);
1270 if (IsGeometry(argv[i]) == MagickFalse)
1271 ThrowCompositeInvalidArgumentException(option,argv[i]);
1274 if (LocaleNCompare("respect-parentheses",option+1,17) == 0)
1276 respect_parenthesis=(*option == '-') ? MagickTrue : MagickFalse;
1279 if (LocaleCompare("resize",option+1) == 0)
1284 if (i == (long) argc)
1285 ThrowCompositeException(OptionError,"MissingArgument",option);
1286 if (IsGeometry(argv[i]) == MagickFalse)
1287 ThrowCompositeInvalidArgumentException(option,argv[i]);
1290 if (LocaleCompare("rotate",option+1) == 0)
1293 if (i == (long) argc)
1294 ThrowCompositeException(OptionError,"MissingArgument",option);
1295 if (IsGeometry(argv[i]) == MagickFalse)
1296 ThrowCompositeInvalidArgumentException(option,argv[i]);
1299 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1303 if (LocaleCompare("sampling-factor",option+1) == 0)
1308 if (i == (long) argc)
1309 ThrowCompositeException(OptionError,"MissingArgument",option);
1310 if (IsGeometry(argv[i]) == MagickFalse)
1311 ThrowCompositeInvalidArgumentException(option,argv[i]);
1314 if (LocaleCompare("scene",option+1) == 0)
1319 if (i == (long) argc)
1320 ThrowCompositeException(OptionError,"MissingArgument",option);
1321 if (IsGeometry(argv[i]) == MagickFalse)
1322 ThrowCompositeInvalidArgumentException(option,argv[i]);
1325 if (LocaleCompare("seed",option+1) == 0)
1330 if (i == (long) (argc-1))
1331 ThrowCompositeException(OptionError,"MissingArgument",option);
1332 if (IsGeometry(argv[i]) == MagickFalse)
1333 ThrowCompositeInvalidArgumentException(option,argv[i]);
1336 if (LocaleCompare("sharpen",option+1) == 0)
1339 if (i == (long) argc)
1340 ThrowCompositeException(OptionError,"MissingArgument",option);
1341 if (IsGeometry(argv[i]) == MagickFalse)
1342 ThrowCompositeInvalidArgumentException(option,argv[i]);
1345 if (LocaleCompare("shave",option+1) == 0)
1350 if (i == (long) (argc-1))
1351 ThrowCompositeException(OptionError,"MissingArgument",option);
1352 if (IsGeometry(argv[i]) == MagickFalse)
1353 ThrowCompositeInvalidArgumentException(option,argv[i]);
1356 if (LocaleCompare("size",option+1) == 0)
1361 if (i == (long) argc)
1362 ThrowCompositeException(OptionError,"MissingArgument",option);
1363 if (IsGeometry(argv[i]) == MagickFalse)
1364 ThrowCompositeInvalidArgumentException(option,argv[i]);
1367 if (LocaleCompare("stegano",option+1) == 0)
1369 composite_options.stegano=0;
1373 if (i == (long) argc)
1374 ThrowCompositeException(OptionError,"MissingArgument",option);
1375 if (IsGeometry(argv[i]) == MagickFalse)
1376 ThrowCompositeInvalidArgumentException(option,argv[i]);
1377 composite_options.stegano=atol(argv[i])+1;
1380 if (LocaleCompare("stereo",option+1) == 0)
1385 composite_options.stereo=MagickFalse;
1389 if (i == (long) argc)
1390 ThrowCompositeException(OptionError,"MissingArgument",option);
1391 if (IsGeometry(argv[i]) == MagickFalse)
1392 ThrowCompositeInvalidArgumentException(option,argv[i]);
1393 flags=ParseAbsoluteGeometry(argv[i],&composite_options.offset);
1394 if ((flags & YValue) == 0)
1395 composite_options.offset.y=composite_options.offset.x;
1396 composite_options.stereo=MagickTrue;
1399 if (LocaleCompare("strip",option+1) == 0)
1401 if (LocaleCompare("support",option+1) == 0)
1403 i++; /* deprecated */
1406 if (LocaleCompare("swap",option+1) == 0)
1411 if (i == (long) (argc-1))
1412 ThrowCompositeException(OptionError,"MissingArgument",option);
1413 if (IsGeometry(argv[i]) == MagickFalse)
1414 ThrowCompositeInvalidArgumentException(option,argv[i]);
1417 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1421 if (LocaleCompare("thumbnail",option+1) == 0)
1426 if (i == (long) argc)
1427 ThrowCompositeException(OptionError,"MissingArgument",option);
1428 if (IsGeometry(argv[i]) == MagickFalse)
1429 ThrowCompositeInvalidArgumentException(option,argv[i]);
1432 if (LocaleCompare("tile",option+1) == 0)
1434 composite_options.tile=(*option == '-') ? MagickTrue : MagickFalse;
1435 (void) CopyMagickString(argv[i]+1,"sans",MaxTextExtent);
1438 if (LocaleCompare("transform",option+1) == 0)
1440 if (LocaleCompare("transparent-color",option+1) == 0)
1445 if (i == (long) (argc-1))
1446 ThrowCompositeException(OptionError,"MissingArgument",option);
1449 if (LocaleCompare("treedepth",option+1) == 0)
1454 if (i == (long) argc)
1455 ThrowCompositeException(OptionError,"MissingArgument",option);
1456 if (IsGeometry(argv[i]) == MagickFalse)
1457 ThrowCompositeInvalidArgumentException(option,argv[i]);
1460 if (LocaleCompare("type",option+1) == 0)
1468 if (i == (long) argc)
1469 ThrowCompositeException(OptionError,"MissingArgument",option);
1470 type=ParseMagickOption(MagickTypeOptions,MagickFalse,argv[i]);
1472 ThrowCompositeException(OptionError,"UnrecognizedImageType",
1476 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1480 if (LocaleCompare("units",option+1) == 0)
1488 if (i == (long) argc)
1489 ThrowCompositeException(OptionError,"MissingArgument",option);
1490 units=ParseMagickOption(MagickResolutionOptions,MagickFalse,
1493 ThrowCompositeException(OptionError,"UnrecognizedUnitsType",
1497 if (LocaleCompare("unsharp",option+1) == 0)
1499 (void) CloneString(&composite_options.compose_args,(char *) NULL);
1503 if (i == (long) argc)
1504 ThrowCompositeException(OptionError,"MissingArgument",option);
1505 if (IsGeometry(argv[i]) == MagickFalse)
1506 ThrowCompositeInvalidArgumentException(option,argv[i]);
1507 (void) CloneString(&composite_options.compose_args,argv[i]);
1508 composite_options.compose=ThresholdCompositeOp;
1511 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1515 if (LocaleCompare("verbose",option+1) == 0)
1517 if ((LocaleCompare("version",option+1) == 0) ||
1518 (LocaleCompare("-version",option+1) == 0))
1520 (void) fprintf(stdout,"Version: %s\n",
1521 GetMagickVersion((unsigned long *) NULL));
1522 (void) fprintf(stdout,"Copyright: %s\n",GetMagickCopyright());
1523 (void) fprintf(stdout,"Features: %s\n\n",GetMagickFeatures());
1526 if (LocaleCompare("virtual-pixel",option+1) == 0)
1534 if (i == (long) argc)
1535 ThrowCompositeException(OptionError,"MissingArgument",option);
1536 method=ParseMagickOption(MagickVirtualPixelOptions,MagickFalse,
1539 ThrowCompositeException(OptionError,
1540 "UnrecognizedVirtualPixelMethod",argv[i]);
1543 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1547 if (LocaleCompare("watermark",option+1) == 0)
1549 (void) CloneString(&composite_options.compose_args,(char *) NULL);
1553 if (i == (long) argc)
1554 ThrowCompositeException(OptionError,"MissingArgument",option);
1555 if (IsGeometry(argv[i]) == MagickFalse)
1556 ThrowCompositeInvalidArgumentException(option,argv[i]);
1557 (void) CloneString(&composite_options.compose_args,argv[i]);
1558 composite_options.compose=ModulateCompositeOp;
1561 if (LocaleCompare("white-point",option+1) == 0)
1566 if (i == (long) argc)
1567 ThrowCompositeException(OptionError,"MissingArgument",option);
1568 if (IsGeometry(argv[i]) == MagickFalse)
1569 ThrowCompositeInvalidArgumentException(option,argv[i]);
1572 if (LocaleCompare("write",option+1) == 0)
1575 if (i == (long) argc)
1576 ThrowCompositeException(OptionError,"MissingArgument",option);
1579 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1584 ThrowCompositeException(OptionError,"UnrecognizedOption",option)
1586 fire=ParseMagickOption(MagickImageListOptions,MagickFalse,option+1) < 0 ?
1587 MagickFalse : MagickTrue;
1588 if (fire != MagickFalse)
1589 FireImageStack(MagickFalse,MagickTrue,MagickTrue);
1592 ThrowCompositeException(OptionError,"UnbalancedParenthesis",argv[i]);
1593 if (i-- != (long) (argc-1))
1594 ThrowCompositeException(OptionError,"MissingAnImageFilename",argv[i]);
1595 if ((image == (Image *) NULL) || (GetImageListLength(image) < 2))
1596 ThrowCompositeException(OptionError,"MissingAnImageFilename",argv[argc-1]);
1597 FinalizeImageSettings(image_info,image,MagickTrue);
1598 if ((image == (Image *) NULL) || (GetImageListLength(image) < 2))
1599 ThrowCompositeException(OptionError,"MissingAnImageFilename",argv[argc-1]);
1603 RemoveImageStack(composite_image);
1604 RemoveImageStack(images);
1605 (void) TransformImage(&composite_image,(char *) NULL,
1606 composite_image->geometry);
1607 RemoveImageStack(mask_image);
1608 if (mask_image != (Image *) NULL)
1610 if ((composite_options.compose == DisplaceCompositeOp) ||
1611 (composite_options.compose == DistortCompositeOp))
1614 Merge Y displacement into X displacement image.
1616 (void) CompositeImage(composite_image,CopyGreenCompositeOp,mask_image,
1618 mask_image=DestroyImage(mask_image);
1623 Set a blending mask for the composition.
1625 images->mask=mask_image;
1626 (void) NegateImage(images->mask,MagickFalse);
1629 status&=CompositeImageList(image_info,&images,composite_image,
1630 &composite_options,exception);
1631 composite_image=DestroyImage(composite_image);
1633 Write composite images.
1635 status&=WriteImages(image_info,images,argv[argc-1],exception);
1636 if (metadata != (char **) NULL)
1641 text=InterpretImageProperties(image_info,images,format);
1642 if (text == (char *) NULL)
1643 ThrowCompositeException(ResourceLimitError,"MemoryAllocationFailed",
1644 GetExceptionMessage(errno));
1645 (void) ConcatenateString(&(*metadata),text);
1646 (void) ConcatenateString(&(*metadata),"\n");
1647 text=DestroyString(text);
1649 images=DestroyImage(images);
1650 RelinquishCompositeOptions(&composite_options);
1652 return(status != 0 ? MagickTrue : MagickFalse);