Android canvas画图操作之切割画布实现方法(clipRect)
程序员文章站
2024-03-04 17:20:12
本文实例讲述了android canvas画图操作之切割画布实现方法。分享给大家供大家参考,具体如下:
android切割画布的历程不算很难,可是理解起来也比较麻烦,这里...
本文实例讲述了android canvas画图操作之切割画布实现方法。分享给大家供大家参考,具体如下:
android切割画布的历程不算很难,可是理解起来也比较麻烦,这里写一下我的理解 但是不一定正确:
canvas.cliprect(30, 30, 70, 70, region.op.xor);
最后一个参数有多个选择分别是:
//difference是第一次不同于第二次的部分显示出来
//replace是显示第二次的
//reverse_difference 是第二次不同于第一次的部分显示
//intersect交集显示
//union全部显示
//xor补集 就是全集的减去交集生育部分显示
import android.content.context; import android.graphics.canvas; import android.graphics.color; import android.graphics.paint; import android.graphics.path; import android.graphics.region; import android.util.attributeset; import android.view.view; public class sbook extends view{ context mcontext; paint mpaint; path mpath; public sbook(context context) { super(context); init(); } public sbook(context context, attributeset attrs) { super(context, attrs); init(); } public sbook(context context, attributeset attrs, int defstyle) { super(context, attrs, defstyle); init(); } private void init(){ mpaint = new paint(); mpaint.setantialias(true); mpaint.setstrokewidth(6); mpaint.settextsize(16); mpaint.settextalign(paint.align.right); mpath = new path(); } protected void ondraw(canvas canvas){ canvas.drawcolor(color.gray); canvas.save(); canvas.translate(10, 10); drawscene(canvas); canvas.restore(); canvas.save(); canvas.translate(160, 10); canvas.cliprect(10, 10, 90, 90); canvas.cliprect(30, 30, 70, 70, region.op.xor); drawscene(canvas); canvas.restore(); canvas.save(); canvas.translate(10, 160); mpath.reset(); // canvas.clippath(mpath); // makes the clip empty // mpath.addcircle(50, 50, 50, path.direction.ccw); mpath.cubicto(0, 0, 100, 0, 100, 100); mpath.cubicto(100, 100, 0, 100, 0, 0); canvas.clippath(mpath, region.op.replace); drawscene(canvas); canvas.restore(); canvas.save(); canvas.translate(160, 160); canvas.cliprect(0, 0, 60, 60); canvas.cliprect(40, 40, 100, 100, region.op.union); drawscene(canvas); canvas.restore(); canvas.save(); canvas.translate(10, 310); canvas.cliprect(0, 0, 60, 60); canvas.cliprect(40, 40, 100, 100, region.op.xor); drawscene(canvas); canvas.restore(); canvas.save(); canvas.translate(160, 310); canvas.cliprect(0, 0, 60, 60); canvas.cliprect(40, 40, 100, 100, region.op.reverse_difference); drawscene(canvas); canvas.restore(); } private void drawscene(canvas canvas) { canvas.cliprect(0, 0, 100, 100); canvas.drawcolor(color.white); mpaint.setcolor(color.red); canvas.drawline(0, 0, 100, 100, mpaint); mpaint.setcolor(color.green); canvas.drawcircle(30, 70, 30, mpaint); mpaint.setcolor(color.blue); canvas.drawtext("clipping", 100, 30, mpaint); } }
更多关于android相关内容感兴趣的读者可查看本站专题:《android图形与图像处理技巧总结》、《android开发入门与进阶教程》、《android调试技巧与常见问题解决方法汇总》、《android多媒体操作技巧汇总(音频,视频,录音等)》、《android基本组件用法总结》、《android视图view技巧总结》、《android布局layout技巧总结》及《android控件用法总结》
希望本文所述对大家android程序设计有所帮助。