首页 > 代码库 > 【读书笔记《Android游戏编程之从零开始》】15.游戏开发基础(剪切区域)

【读书笔记《Android游戏编程之从零开始》】15.游戏开发基础(剪切区域)

剪切区域也称为可视区域,是由画布进行设置的;它指的是在画布上设置一块区域,当画布一旦设置了可视区域,那么除此区域外,绘制的任何内容都将看不到;可视区域可以是圆形、矩形等等。

 画布提供了三种设置可视区域的方法。

1.通过坐标,设置矩形可视区域
clipRect(int left,int top,int right,int bottom)
作用:为画布设置矩形可视区域
第一、二个参数:为可视区域的左上角
第三、四个参数:为可视区域的右下角

2.利用 Path 来设置可视区域的形状
clipPath(Path path)
作用:为画布设置可视区域
参数:Path实例

3.利用 Region 来对画布设置可视区域
clipRegion(Region region)
作用:为画布设置可视区域
参数:Region 实例

Region 表示区域的集合,所以它可以设置多个区域块,而且可以通过这些区域块之间的关系来处理一些问题;比如 Region 设置它所有区域块相交的区域是否可见、设置相交区域只让交集显示等等。

Region 常用函数:
op(Rect rect,Op op)
作用:设置区域块
第一个参数:Rect 实例
第二个参数:Region.Op 静态值,表示区域块的显示方式。其中区域块的显示方式如下:
Region.Op.UNION: 区域全部显示
Region.Op.INTERSECT:区域的交集显示
Region.Op.XOR:不显示交集区域


下面是实例演示,效果图如下:

创建新项目,游戏框架为 SurfaceView 游戏框架。具体步骤参照“11.游戏开发基础(SurfaceView 游戏框架、View 和 SurfaceView 的区别)”。

修改 MySurfaceView 类中的绘图函数如下:

    private void myDraw() {        try {            canvas = sfh.lockCanvas();            if (canvas != null) {                    //通过图片资源生成一张Bitmap 位图                Bitmap bmp = BitmapFactory.decodeResource(this.getResources(), R.drawable.pic01);                                canvas.save();                canvas.drawText("原图:", 20, 20, paint);                canvas.drawBitmap(bmp, 20, 30,paint);                canvas.restore();                                canvas.save();                canvas.drawText("通过坐标,设置矩形可视区域:", 20, 320, paint);                /**                 * 为画布设置矩形可视区域                 * 第一、二个参数为可视区域的左上角                 * 第三、四个参数为可视区域的右下角                 */                canvas.clipRect(20,330,bmp.getWidth()+20,bmp.getHeight()/2+330);                canvas.drawBitmap(bmp, 20, 330,paint);                canvas.restore();                                canvas.save();                canvas.drawText("利用 Path 来设置可视区域的形状,这里为圆形可视区域:", 20, 620, paint);                Path path = new Path();                path.addCircle(20+bmp.getWidth()/2, 630+bmp.getHeight()/2, bmp.getWidth()/2, Direction.CCW);                /**                 * 为画布设置可视区域                 * 参数:Path实例                 * 利用Paht 可以为位图设置任何需要的可视区域,这里是设置一个圆形可视区域。                 */                canvas.clipPath(path);                canvas.drawBitmap(bmp, 20, 630, paint);                canvas.restore();                                canvas.save();                canvas.drawText("利用 Region 来对画布设置可视区域:", 20, 920, paint);                Region region = new Region();                //区域块全部显示                region.op(new Rect(20,930,120,1030), Region.Op.UNION);                //不显示交集区域                region.op(new Rect(50,930,100,1080), Region.Op.XOR);                canvas.clipRegion(region);                canvas.drawBitmap(bmp, 20, 930, paint);                canvas.restore();                }        } catch (Exception e) {        } finally {            if (canvas != null) {                sfh.unlockCanvasAndPost(canvas);            }        }    }

 

【读书笔记《Android游戏编程之从零开始》】15.游戏开发基础(剪切区域)