渲染器 Shader BitmapShader
渲染模式示例代码
public class LinearGradientView extends View {private Paint mPaint = null;private Shader mLinearGradient11 = null;private Shader mLinearGradient12 = null;private Shader mLinearGradient13 = null;private Shader mLinearGradient21 = null;private Shader mLinearGradient22 = null;private Shader mLinearGradient23 = null;private Shader mLinearGradient31 = null;private Shader mLinearGradient32 = null;private Shader mLinearGradient33 = null;public LinearGradientView(Context context) {super(context);// 第一第二个参数表示渐变起点,可以设置在对角等任意位置;第三第四个参数表示渐变终点;第五个参数表示渐变颜色;// 第六个参数可以为空,表示坐标值为0-1 new float[] {0.25f, 0.5f, 0.75f, 1 } 如果为空,颜色均匀分布,沿梯度线。mLinearGradient11 = new LinearGradient(0, 0, 0, 200, new int[] { Color.RED, Color.GREEN, Color.BLUE, Color.BLACK }, null, TileMode.CLAMP);mLinearGradient12 = new LinearGradient(0, 0, 0, 300, new int[] { Color.RED, Color.GREEN, Color.BLUE, Color.BLACK }, new float[] { 0, 0.1f, 0.5f, 0.5f }, TileMode.CLAMP);mLinearGradient13 = new LinearGradient(0, 0, 0, 400, new int[] { Color.RED, Color.GREEN, Color.BLUE }, null, TileMode.CLAMP);mLinearGradient21 = new LinearGradient(0, 320, 0, 320 + 200, new int[] { Color.RED, Color.GREEN, Color.BLUE, Color.BLACK }, null, TileMode.MIRROR);mLinearGradient22 = new LinearGradient(0, 320, 0, 320 + 100, new int[] { Color.RED, Color.GREEN, Color.BLUE }, null, TileMode.MIRROR);mLinearGradient23 = new LinearGradient(0, 320, 0, 320 + 100, new int[] { Color.RED, Color.GREEN, Color.BLUE }, new float[] { 0, 0.1f, 0.5f }, TileMode.MIRROR);mLinearGradient31 = new LinearGradient(0, 640, 0, 640 + 200, new int[] { Color.RED, Color.GREEN, Color.BLUE, Color.BLACK }, null, TileMode.REPEAT);mLinearGradient32 = new LinearGradient(0, 640, 0, 640 + 100, new int[] { Color.RED, Color.GREEN, Color.BLUE }, null, TileMode.REPEAT);mLinearGradient33 = new LinearGradient(0, 640, 0, 640 + 100, new int[] { Color.RED, Color.GREEN, Color.BLUE }, new float[] { 0, 0.1f, 0.5f }, TileMode.REPEAT);mPaint = new Paint();}@Overrideprotected void onDraw(Canvas canvas) {//重复最后一个像素mPaint.setStrokeWidth(2);mPaint.setShader(mLinearGradient11);canvas.drawRect(0, 0, 200, 300, mPaint);//200-300之间全部是最后的黑色mPaint.setShader(mLinearGradient12);canvas.drawRect(210, 0, 410, 300, mPaint);//0.5之后全部是黑色了mPaint.setShader(mLinearGradient13);canvas.drawRect(420, 0, 620, 300, mPaint); // LinearGradient的高度小于要绘制的矩形的高度时才会有重复、镜像等效果canvas.drawLine(0, 310, 720, 310, mPaint);//镜像效果mPaint.setShader(mLinearGradient21);canvas.drawRect(0, 320, 200, 620, mPaint);mPaint.setShader(mLinearGradient22);canvas.drawRect(210, 320, 410, 620, mPaint);mPaint.setShader(mLinearGradient23);canvas.drawRect(420, 320, 620, 620, mPaint);canvas.drawLine(0, 630, 720, 630, mPaint);//重复效果mPaint.setShader(mLinearGradient31);canvas.drawRect(0, 640, 200, 940, mPaint);mPaint.setShader(mLinearGradient32);canvas.drawRect(210, 640, 410, 940, mPaint);mPaint.setShader(mLinearGradient33);canvas.drawRect(420, 640, 620, 940, mPaint);}}
渲染器示例代码
public class MyShaderView extends View {// Shader渲染器,专门用来渲染图像以及一些几何图形private BitmapShader bitmapShader; //bitmap渲染器,主要用来渲染图像private LinearGradient linearGradient; //线性渲染private RadialGradient radialGradient; //环形渲染private SweepGradient sweepGradient; //扫描渐变,围绕一个中心点扫描渐变就像电影里那种雷达扫描,用来梯度渲染private ComposeShader composeShader; //混合渲染器,可以和其他几个子类组合起来使用private Bitmap bitmap;/**Bitmap的宽高*/private int width, height;private Paint paint;/**渐变颜色数组*/private final int[] colors = { Color.RED, Color.GREEN, Color.BLUE, Color.YELLOW };/**用来指定颜色数组的相对位置,若为null则均匀分布*/private final float[] positions = null;public MyShaderView(Context context) {super(context);bitmap = ((BitmapDrawable) getResources().getDrawable(R.drawable.icon)).getBitmap();width = bitmap.getWidth();height = bitmap.getHeight();paint = new Paint();}@SuppressLint("DrawAllocation")@Overrideprotected void onDraw(Canvas canvas) {super.onDraw(canvas);canvas.drawColor(Color.WHITE); //背景色//将Bitmap截取为圆形、圆角矩形canvas.drawBitmap(bitmap, 0, 0, paint);//原图bitmapShader = new BitmapShader(bitmap, TileMode.MIRROR, TileMode.MIRROR);paint.setShader(bitmapShader);canvas.drawOval(new RectF(width, 0, width * 2, height), paint);//圆形渲染图canvas.drawRoundRect(width * 2, 0, width * 3, height, 30, 30, paint);//矩形渲染图//绘制线性渐变的矩形linearGradient = new LinearGradient(0, 200, 400, 400, colors, positions, TileMode.REPEAT);// 渐变起 初点/终点坐标 x/y 位置;paint.setShader(linearGradient);canvas.drawRect(0, 200, 400, 400, paint);//渲染范围最好和图形大小一致//绘制环形渐变的圆和矩形radialGradient = new RadialGradient(100, 500, 100, colors, positions, TileMode.REPEAT);// 中心坐标、半径paint.setShader(radialGradient);canvas.drawCircle(100, 500, 100, paint);canvas.drawRect(200, 400, 300, 600, paint);radialGradient = new RadialGradient(300, 500, 100, colors, positions, TileMode.MIRROR);paint.setShader(radialGradient);canvas.drawCircle(400, 500, 100, paint);canvas.drawRect(500, 400, 600, 600, paint);//绘制梯形渐变的矩形sweepGradient = new SweepGradient(300, 710, colors, positions);//中心坐标paint.setShader(sweepGradient);canvas.drawRect(0, 610, 600, 810, paint);//绘制混合渐变(线性与环形混合)的矩形linearGradient = new LinearGradient(0, 820, 300, 1120, colors, positions, TileMode.REPEAT);composeShader = new ComposeShader(linearGradient, bitmapShader, PorterDuff.Mode.SRC_OVER);paint.setShader(composeShader);canvas.drawRect(0, 820, 600, 1120, paint);}}
渲染器 Shader BitmapShader的更多相关文章
- 通过渲染器Shader实现图像变换效果
在上一篇文章中,一起学习了通过设定画笔风格来实现图形变换,没读过的朋友可以点击下面链接: http://www.cnblogs.com/fuly550871915/p/4886455.html 是不是 ...
- Android渲染器Shader:环状放射渐变渲染器RadialGradient(三)
Android渲染器Shader:环状放射渐变渲染器RadialGradient(三) Android RadialGradient渲染器提供一种环状.发散.放射形状的渐变渲染器. 写一个例子: ...
- Android渲染器Shader:梯度渐变扫描渲染器SweepGradient(二)
Android渲染器Shader:梯度渐变扫描渲染器SweepGradient(二) 附录文章1介绍了线性渐变渲染器. Android的SweepGradient梯度渐变扫描,重点是在构造Swe ...
- Android渲染器Shader:LinearGradient(一)
Android渲染器Shader:LinearGradient(一) LinearGradient是Android的线性渲染器.我写5个LinearGradient渲染器渲染后的View表现结果 ...
- Android Shader渲染器:BitmapShader图片渲染
public class BitmapShader extends Shader BitmapShader, Shader家族的 专门处理图片渲染的 构造方法: public BitmapShade ...
- 关于 android的 渲染器 Shader
因为公司在 自定义的画图上面比较苛刻(各种要求= =),最后又是改来改去的.反正是 Shader起到很大作用,特此记录一下下.在achartengine的基础上没有能满足他们= = androd 提供 ...
- 基于OpenGL编写一个简易的2D渲染框架-09 重构渲染器-Shader
Shader 只是进行一些简单的封装,主要功能: 1.编译着色程序 2.绑定 Uniform 数据 3.根据着色程序的顶点属性传递顶点数据到 GPU 着色程序的编译 GLuint Shader::cr ...
- android 开发 View _13 绘制图片与BitmapShader位图的图像渲染器
BitmapShader位图的图像渲染器 TileMode 模式 Shader.TileMode.CLAMP 边缘拉伸. Shader.TileMode.MIRROR 在水平方向和垂直方向交替景象, ...
- Android学习笔记12:图像渲染(Shader)
在Android中,提供了Shader类专门用来渲染图像以及一些几何图形. Shader类包括了5个直接子类,分别为:BitmapShader.ComposeShader.LinearGradient ...
随机推荐
- phpcms v9自定义表单提交后返回上一页实现方法
PHPcms v9中提交自定义表单后默认都是回到首页的,是不是感觉很不爽! 接下来,就说下phpcms v9自定义表单提交后返回上一页实现方法. 1.找到这个文件 phpcms\modules\for ...
- get_magic_quotes_gpc() 内置函数
get_magic_quotes_gpc()函数 在PHP中是内置的函数,这个函数的作用就是得到php.ini设置中magic_quotes_gpc选项的值. 当magic_quotes_gpc=On ...
- php中json_decode()和json_encode()
1.json_decode() json_decode (PHP 5 >= 5.2.0, PECL json >= 1.2.0) json_decode — 对 JSON 格式的字符串进行 ...
- CentOS安装rar、unrar解压缩软件的方法
闲话不说,centos上如何安装rar.unrar在线解压缩软件呢?如果您的centos是32位的,执行如下命令: wget http://www.rarsoft.com/rar/rarlinux-3 ...
- ARM9的MMU
一 页表 1. 页表是放置在RAM(一般为DRAM)中的一个数据段. 2. ARM的地址空间为2^32字节,即4G字节. 3. 一级页表总共有4096条记录,每条记录对应的地址块为1M,一级页表中的记 ...
- laravel框架——上传、下载文件
文件上传 在config文件夹下新建一个 项目名.php return [ 'title' => 'My Test', 'posts_per_page' => 5, 'uploads' = ...
- OC中的@interface和java中的区别以及 @implementation @protocol
java 在java中的interface是‘接口’的意思,而java的类声明用class,即接口用interface声明,类是用class声明,是两个独立的部分. 只有在类声明要实现某个接口时, ...
- iOS开发网络篇-JSON文件的解析
一.什么是JSON数据 1.JSON的简单介绍 JSON:是一种轻量级的传输数据的格式,用于数据的交互 JSON是javascript语言的一个子集.javascript是个脚本语言(不需要编译),用 ...
- native2ascii 在 Mac终端的转码
打开终端,输入 native2ascii 回车 然后输入想要转码的 中文 回车 自动会出现 通用的 unicode编码. 默认应该是 utf-8 格式
- angular-utils-pagination 使用案例
angular-utils-pagination是基于angular,bootstrap,jquery的一个分页插件,详细介绍以及使用方法参照: Git:https://github.com/mich ...

