zoukankan      html  css  js  c++  java
  • 【读书笔记《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);
                }
            }
        }
  • 相关阅读:
    如何使用phantomJS来模拟一个HTML元素的鼠标悬停
    nodejs中使用cheerio爬取并解析html网页
    Node.js 动态网页爬取 PhantomJS 使用入门(转)
    一口一口吃掉Hibernate(五)——一对多单向关联映射
    开源 免费 java CMS
    [WinForm]dataGridView导出到EXCEL
    关键帧和动画
    uva 696
    uva 11181
    IE下target获得焦点时存在虚线的问题
  • 原文地址:https://www.cnblogs.com/yc-755909659/p/4164979.html
Copyright © 2011-2022 走看看