pixel[RedPixelChannel]=image->background_color.red;
pixel[GreenPixelChannel]=image->background_color.green;
pixel[BluePixelChannel]=image->background_color.blue;
+ pixel[BlackPixelChannel]=image->background_color.black;
pixel[AlphaPixelChannel]=image->background_color.alpha;
return(MagickFalse);
}
pixel[RedPixelChannel]=image->background_color.red;
pixel[GreenPixelChannel]=image->background_color.green;
pixel[BluePixelChannel]=image->background_color.blue;
+ pixel[BlackPixelChannel]=image->background_color.black;
pixel[AlphaPixelChannel]=image->background_color.alpha;
return(MagickFalse);
}
%
*/
MagickExport MagickBooleanType GetOneVirtualMagickPixel(const Image *image,
- const ssize_t x,const ssize_t y,PixelInfo *pixel,
- ExceptionInfo *exception)
+ const ssize_t x,const ssize_t y,PixelInfo *pixel,ExceptionInfo *exception)
{
CacheInfo
*cache_info;
pixel[RedPixelChannel]=image->background_color.red;
pixel[GreenPixelChannel]=image->background_color.green;
pixel[BluePixelChannel]=image->background_color.blue;
+ pixel[BlackPixelChannel]=image->background_color.black;
pixel[AlphaPixelChannel]=image->background_color.alpha;
return(MagickFalse);
}
pixel[RedPixelChannel]=image->background_color.red;
pixel[GreenPixelChannel]=image->background_color.green;
pixel[BluePixelChannel]=image->background_color.blue;
+ pixel[BlackPixelChannel]=image->background_color.black;
pixel[AlphaPixelChannel]=image->background_color.alpha;
return(MagickFalse);
}
pixel[RedPixelChannel]=image->background_color.red;
pixel[GreenPixelChannel]=image->background_color.green;
pixel[BluePixelChannel]=image->background_color.blue;
+ pixel[BlackPixelChannel]=image->background_color.black;
pixel[AlphaPixelChannel]=image->background_color.alpha;
return(MagickFalse);
}
gamma,
Sa;
+ register ssize_t
+ i;
+
/*
Compose pixel p over pixel q with the given opacities.
*/
- if (fabs(alpha-TransparentAlpha) < MagickEpsilon)
- {
- if (composite != q)
- {
- SetPixelRed(image,GetPixelRed(image,q),composite);
- SetPixelGreen(image,GetPixelGreen(image,q),composite);
- SetPixelBlue(image,GetPixelBlue(image,q),composite);
- SetPixelAlpha(image,GetPixelAlpha(image,q),composite);
- }
- return;
- }
Sa=QuantumScale*alpha;
Da=QuantumScale*beta,
gamma=Sa*(-Da)+Sa+Da;
-#if !defined(MAGICKCORE_HDRI_SUPPORT)
- SetPixelAlpha(image,(Quantum) (QuantumRange*gamma+0.5),composite);
gamma=1.0/(gamma <= MagickEpsilon ? 1.0 : gamma);
- SetPixelRed(image,(Quantum) (gamma*MagickOver_((MagickRealType) p->red,
- alpha,(MagickRealType) GetPixelRed(image,q),beta)+0.5),composite);
- SetPixelGreen(image,(Quantum) (gamma*MagickOver_((MagickRealType) p->green,
- alpha,(MagickRealType) GetPixelGreen(image,q),beta)+0.5),composite);
- SetPixelBlue(image,(Quantum) (gamma*MagickOver_((MagickRealType) p->blue,
- alpha,(MagickRealType) GetPixelBlue(image,q),beta)+0.5),composite);
-#else
- SetPixelAlpha(image,QuantumRange*gamma,composite);
- gamma=1.0/(gamma <= MagickEpsilon ? 1.0 : gamma);
- SetPixelRed(image,(Quantum) (gamma*MagickOver_((MagickRealType) p->red,
- alpha,(MagickRealType) GetPixelRed(image,q),beta)),composite);
- SetPixelGreen(image,(Quantum) (gamma*MagickOver_((MagickRealType) p->green,
- alpha,(MagickRealType) GetPixelGreen(image,q),beta)),composite);
- SetPixelBlue(image,(Quantum) (gamma*MagickOver_((MagickRealType) p->blue,
- alpha,(MagickRealType) GetPixelBlue(image,q),beta)),composite);
-#endif
+ for (i=0; i < (ssize_t) GetPixelChannels(image); i++)
+ {
+ PixelChannel
+ channel;
+
+ PixelTrait
+ traits;
+
+ traits=GetPixelChannelMapTraits(image,(PixelChannel) i);
+ channel=GetPixelChannelMapChannel(image,(PixelChannel) i);
+ if (traits == UndefinedPixelTrait)
+ continue;
+ switch (channel)
+ {
+ case RedPixelChannel:
+ {
+ composite[i]=ClampToQuantum(gamma*MagickOver_((MagickRealType) p->red,
+ alpha,(MagickRealType) q[i],beta));
+ break;
+ }
+ case GreenPixelChannel:
+ {
+ composite[i]=ClampToQuantum(gamma*MagickOver_((MagickRealType) p->green,
+ alpha,(MagickRealType) q[i],beta));
+ break;
+ }
+ case BluePixelChannel:
+ {
+ composite[i]=ClampToQuantum(gamma*MagickOver_((MagickRealType) p->blue,
+ alpha,(MagickRealType) q[i],beta));
+ break;
+ }
+ case BlackPixelChannel:
+ {
+ composite[i]=ClampToQuantum(gamma*MagickOver_((MagickRealType) p->black,
+ alpha,(MagickRealType) q[i],beta));
+ break;
+ }
+ case AlphaPixelChannel:
+ {
+ composite[i]=ClampToQuantum(QuantumRange*gamma);
+ break;
+ }
+ default:
+ break;
+ }
+ }
}
static inline void CompositePixelInfoOver(const PixelInfo *p,
MagickBooleanType
status;
- Quantum
- pixel[MaxPixelChannels];
-
pattern=draw_info->fill_pattern;
#if defined(MAGICKCORE_OPENMP_SUPPORT) && (_OPENMP >= 200203)
#pragma omp critical
#endif
- status=GetOneVirtualMethodPixel(pattern,TileVirtualPixelMethod,x+
- pattern->tile_offset.x,y+pattern->tile_offset.y,pixel,exception);
- fill->red=(double) pixel[RedPixelChannel];
- fill->green=(double) pixel[GreenPixelChannel];
- fill->blue=(double) pixel[BluePixelChannel];
- fill->alpha=(double) pixel[AlphaPixelChannel];
+ status=GetOneVirtualMagickPixel(pattern,x+pattern->tile_offset.x,
+ y+pattern->tile_offset.y,fill,exception);
return(status);
}
}
MagickBooleanType
status;
- Quantum
- pixel[MaxPixelChannels];
-
pattern=draw_info->stroke_pattern;
#if defined(MAGICKCORE_OPENMP_SUPPORT) && (_OPENMP >= 200203)
#pragma omp critical
#endif
- status=GetOneVirtualMethodPixel(pattern,TileVirtualPixelMethod,x+
- pattern->tile_offset.x,y+pattern->tile_offset.y,pixel,exception);
- stroke->red=(double) pixel[RedPixelChannel];
- stroke->green=(double) pixel[GreenPixelChannel];
- stroke->blue=(double) pixel[BluePixelChannel];
- stroke->alpha=(double) pixel[AlphaPixelChannel];
+ status=GetOneVirtualMagickPixel(pattern,x+pattern->tile_offset.x,y+
+ pattern->tile_offset.y,stroke,exception);
return(status);
}
}