When I tried to make the picture black and white, I learned about ShaderMask. Today, I will simply learn and try it.
ShaderMask
ShaderMask is a mask layer added to subwidget to display different mask effects, and can be used with BlendMode to display different image blending effects.
Source code analysis
const ShaderMask({
Key key,
@required this.shaderCallback,
this.blendMode = BlendMode.modulate,
Widget child,
})
Copy the code
Analysis of the source code available, ShaderMask inherited from SingleChildRenderObjectWidget, is mainly used for rendering. ShaderCallback is used to generate the callback of the mask mask; BlendMode is used to adjust the display effect of mask layer;
Case try
ShaderCallback
ShaderCallback is used to call the Widget’s ShaderCallback so that the shader can be customized based on the size and location of the child Widget; You can use the Gradients class to define the effect of the shader; When setting the mask effect of the text, it is recommended to set the color of the text to white.
A LinearGradient
const LinearGradient({
this.begin = Alignment.centerLeft,
this.end = Alignment.centerRight,
@required List<Color> colors,
List<double> stops,
this.tileMode = TileMode.clamp,
GradientTransform transform,
})
Copy the code
Lineargradients are used for 2D linear gradients, where begin and end are used for the two anchors at the beginning and end. Colors is the list of colors set during the gradient. Stops are the percentage of stops that change gradient in a color list; Note that the colors and stops list should be of the same length;
return ShaderMask( shaderCallback: (rect) => LinearGradient( begin: Alignment.topCenter, end: Alignment. BottomCenter, colors: [colors. DeepOrange. WithOpacity (0.6), colors, yellow and colors. The green], stops: [0.2, 0.5, 0.9],).createshader (Rect), Child: _itemText(_paraStr));Copy the code
2. RadialGradient
Const RadialGradient({this.center = Alignment. Center, this.radius = 0.5, @required List<Color> colors, List<double> stops, this.tileMode = Tilemode. clamp, this.focal = 0.0, GradientTransform transform,})Copy the code
RadialGradient is used for 2D, RadialGradient, with center as the center of the circle and radius as the radius width gradient layer by layer;
return ShaderMask( shaderCallback: (Rect bounds) { return RadialGradient( center: Alignment.center, radius: 0.5 colors: [colors. DeepOrange. WithOpacity (0.6), colors, yellow and colors. The green], stops: [0.1, 0.5, 0.9], tileMode: TileMode.mirror) .createShader(bounds); }, child: _itemText(_paraStr));Copy the code
3. SweepGradient
Const SweepGradient({this.center = Alignment. Center, this.startAngle = 0.0, this.endAngle = math.pi * 2, @required List<Color> colors, List<double> stops, this.tileMode = TileMode.clamp, GradientTransform transform, })Copy the code
SweepGradient is 2D laser scanning gradient, where Center is laser scanning center; StartAngle and endAngle are the radians at the beginning and end of the scan respectively. Other attributes are the same;
return ShaderMask( shaderCallback: (Rect bounds) { return SweepGradient( colors: [Colors. DeepOrange withOpacity (0.6), Colors, yellow, and Colors. The green], stops: [0.3, 0.6, 0.9], the center: Alignment.center, ).createShader(bounds); }, child: _itemText(_paraStr)); return ShaderMask( shaderCallback: (Rect bounds) { return SweepGradient( colors: [Colors. DeepOrange withOpacity (0.6), Colors, yellow, and Colors. The green], startAngle: PI * 0.5, endAngle: 2 * PI * 0.6, center: align.center,).createshader (bounds); }, child: _itemText(_paraStr));Copy the code
BlendMode
BlendMode is the blending mode for drawing, which can be used to create other effects. Such as black and white mode, X-ray mode and so on;
return ShaderMask(
shaderCallback: (Rect bounds) {
return LinearGradient(colors: [Color(0xFF704214), Colors.brown]).createShader(bounds);
},
blendMode: BlendMode.color,
child: Container(width: 100, height: 100, child: Image.asset('images/icon_hzw01.jpg')));
return ShaderMask(
shaderCallback: (Rect bounds) {
return LinearGradient(colors: [Colors.black, Colors.white]).createShader(bounds);
},
blendMode: BlendMode.hue,
child: Container(width: 100, height: 100, child: Image.asset('images/icon_hzw01.jpg')));
Copy the code
ShaderMask case source code
The main idea is to set up a black and white photo, which is a simple extension of the ShaderMask shader. Xiao CAI has not explored the deep principle, if there is a mistake, please give more guidance!
Source: Little Monk A Ce