Path相关评论的方法(一)

Path相关评论的方法(一)

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

以前的主要是关于Canvas的translate(平移) 、scale(缩放) 、rotate(旋转) 、skew(错切)。接下来几篇主要讲下android里的Path(封装了贝塞尔曲线)& Canvas里的drawPath(path,paint);

非常多人听到贝塞尔曲线,就认为似乎挺高端大气上档次。后面会和大家一起揭开它的面纱,一睹真容;

Path(路径):

我们先看看Path类里有哪些方法

Path相关评论的方法(一)

Path相关评论的方法(一)

咱们从上往下看:

构造函数有两个。各自是

    /**
     * Create an empty path
     */
    public Path() {
        mNativePath = init1();
        mDetectSimplePaths = HardwareRenderer.isAvailable();
    }

    /**
     * Create a new path, copying the contents from the src path.
     *
     * @param src The path to copy from when initializing the new path
     */
    public Path(Path src) {
        int valNative = 0;
        if (src != null) {
            valNative = src.mNativePath;
        }
        mNativePath = init2(valNative);
        mDetectSimplePaths = HardwareRenderer.isAvailable();
    }


这没啥好说的,另外一种就是直接复用src 里设置的属性创建一个新的Path对象。

path.reset():清除掉path里的线条和曲线,可是不会改变它的fill-type(后面setFillType再说);

path.rewind():清除掉path里的线条和曲线,可是会保留内部的数据结构以便重用;

path.set(Path src);用src的内容替换原path的内容,一起看个小样例:

创建一个path,加入一个实心圆到path里

mEndPath = new Path();
mEndPath.addCircle(300, 300, 100, Direction.CW);

绘制该path:

canvas.drawPath(mEndPath, mPaint);

效果例如以下,无可厚非:

Path相关评论的方法(一)

此时在path里再加入一个矩形:

mEndPath = new Path();
mEndPath.addCircle(300, 300, 100, Direction.CW);
mEndPath.addRect(new RectF(50, 50, 250, 200), Direction.CW);

效果例如以下:

Path相关评论的方法(一)

做例如以下修改:

mEndPath = new Path();
mEndPath.addCircle(300, 300, 100, Direction.CW);
//mEndPath.addRect(new RectF(50, 50, 250, 200), Direction.CW);

mSrcPath = new Path();
mSrcPath.addRect(new RectF(50, 50, 250, 200), Direction.CW);
mEndPath.set(mSrcPath);

直接执行,假设在4.0以上的机器上(4.0及以上硬件加速默认开启),会发现屏幕上什么都没有了,说明该方法会受到硬件加速的影响,关掉硬件加速,再看效果:

Path相关评论的方法(一)

以下一起来看看Path 的 FillType - 填充模式:

android里定义了四种FillType,各自是:

 WINDING          (0),

 EVEN_ODD         (1),

 INVERSE_WINDING    (2),

 INVERSE_EVEN_ODD   (3)

有张图能够专门用来说明这四种模式的区别:

Path相关评论的方法(一)

以上图示已经很清晰,我们还是用例如以下代码做下測试:

mEndPath = new Path();mEndPath.addCircle(300, 300, 150, Direction.CW);mEndPath.addCircle(380, 380, 150, Direction.CW);mEndPath.setFillType(FillType.INVERSE_EVEN_ODD);mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);mPaint.setStyle(Style.FILL);mPaint.setColor(Color.RED);

測试结果例如以下图:

Path相关评论的方法(一)

不设置FillType:

Path相关评论的方法(一)           Path相关评论的方法(一)

setFillType(FillType.WINDING)          setFillType(FillType.EVEN_ODD): 


Path相关评论的方法(一)           Path相关评论的方法(一)

setFillType(FillType.INVERSE_WINDING):   setFillType(FillType.INVERSE_EVEN_ODD):


依据以上图示,Path的FillType能够总结例如以下:

1.Path的默认FillType为 FillType.WINDING;

2.作用的范围为绘制 Path 的 Canvas 总体。而非 path 所在区域;

3.FillType.WINDING:取path全部所在区域;

4.FillType.EVEN_ODD:取path所在并不相交区域;

5.FillType.INVERSE_WINDING:取path全部未占区域;

6.FillType.INVERSE_EVEN_ODD:取path未占或相交区域;

以下看看和填充模式相关的几个方法:

getFillType():不用多说。返回 Path 的填充模式;

setFillType():设置 Path 的填充模式;

isInverseFillType():是否是 逆 填充模式:

WINDING 和 EVEN_ODD 返回false,INVERSE_WINDING 和 INVERSE_EVEN_ODD 返回true。

toggleInverseFillType():切换相反的填充模式。举个小样例:

        mEndPath = new Path();        mEndPath.addCircle(300, 300, 150, Direction.CW);        mEndPath.addCircle(380, 380, 150, Direction.CW);        mEndPath.setFillType(FillType.WINDING);        mEndPath.toggleInverseFillType();        mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);        mPaint.setStyle(Style.FILL);        mPaint.setColor(Color.RED);

此时给Path设置了WINDING的填充模式,调用toggleInverseFillType()。终于的模式为:

FillType.INVERSE_WINDING

Path相关评论的方法(一)

isEmpty():path是否为空,假设path不包括不论什么线条和曲线,则返回true,否则返回false;

isRect(RectF rect):假设path指定的是一个rect,则返回true,否则返回false。假设返回true & rect 不为null。则将该rect设置为path 的区域;

computeBounds(RectF bounds,boolean exact):计算path所在区域,并将结果写入bounds,假设整个path仅仅包括0或1个点,将返回(0,0,0,0):

用例如以下代码做下測试:

        mComputeRect = new RectF();        mEndPath = new Path();        mEndPath.addCircle(380, 380, 150, Direction.CW);        mEndPath.addRect(new RectF(200, 300, 500, 500), Direction.CW);        mEndPath.computeBounds(mComputeRect, false);        Toast.makeText(                mContext,                "" + mComputeRect.left + "," + mComputeRect.top + "," + mComputeRect.right + ","                        + mComputeRect.bottom,                Toast.LENGTH_LONG).show();

返回结果为(200,230,530,530),即path所含内容的边界区域

Path相关评论的方法(一)

incReserve(int extraPtCount):提示path将会添加extraPtCount个点。这能使path有效率的分配它的存储空间。


好了,这篇就主要介绍这些方法。后面主要介绍 Path 里 XXXTo 和 addXXX 相关的方法,最后我们再一起用Path做个样例!


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117820.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 【软考】系统集成项目管理工程师(一)信息化知识[通俗易懂]

    【软考】系统集成项目管理工程师(一)信息化知识[通俗易懂]软考中级——系统集成项目管理工程师备考干货第一章:信息化知识。

    2022年8月31日
    3
  • QMovie的使用

    QMovie的使用QMovie是一个可以存放动态视频的类今天第一次使用,记录一下一般是配合QLabel使用的,可以用来存放GIF动态图 m_background=newQLabel(this);m_background->setGeometry(0,0,MENU_WINDOW_WIDTH,MENU_WINDOW_HEIGHT);QMovie*backgroundMovie=newQMovie(“:/images/menu/MenuBackground.gif”,QByteArra

    2022年6月16日
    61
  • bs与cs的区别简述_bs和cs页面

    bs与cs的区别简述_bs和cs页面B/SB/S即:Browser与Server,中文意思:浏览器端与服务器端架构,这种架构是从用户层面来划分的,Browser浏览器,其实也是一种Client客户端,只是这个客户端不需要大家去安装什么应用程序,只需在浏览器上通过HTTP请求服务器端相关的资源(网页资源),客户端Browser浏览器就能进行增删改查。不依赖用户的电脑操作系统环境,只与浏览器环境有关,当然由于网页复杂性,又延伸出网页前端技术与后端技术,前端技术指的是在浏览器上编程的技术,比如:JS,HTML,CSS,这些前端技术是运行在客户端B

    2022年10月16日
    2
  • 如何在win10上同时安装python2和python3

    如何在win10上同时安装python2和python3

    2021年10月16日
    61
  • 交叉熵损失函数原理详解[通俗易懂]

    交叉熵损失函数原理详解[通俗易懂]交叉熵损失函数原理详解之前在代码中经常看见交叉熵损失函数(CrossEntropyLoss),只知道它是分类问题中经常使用的一种损失函数,对于其内部的原理总是模模糊糊,而且一般使用交叉熵作为损失函数时,在模型的输出层总会接一个softmax函数,至于为什么要怎么做也是不懂,所以专门花了一些时间打算从原理入手,搞懂它,故在此写一篇博客进行总结,以便以后翻阅。交叉熵简介交叉熵是信息论中的一个…

    2022年6月26日
    33
  • C#网络编程(基本概念和操作) – Part.1

    C#网络编程(基本概念和操作) – Part.1

    2021年8月30日
    50

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号