Android Paint 抗锯齿画线模糊

本文涉及的产品
模型训练 PAI-DLC,100CU*H 3个月
交互式建模 PAI-DSW,每月250计算时 3个月
模型在线服务 PAI-EAS,A10/V100等 500元 1个月
简介: Android Paint 抗锯齿画线模糊

背景


Android 开发过程中, 或多或少会遇到需要使用自定义控件的情况, 而Paint作为画笔, 在整个开发过程中有着至关重要的地位, 用好它, 能让自定义控件展示出你期望的效果, 用不好… 或许会抱怨, 这平台/这工具/这类怎么设计得如此难用.


就如同本文将要阐述的问题, 希望能给遇到相似问题的朋友一点帮助, 若无碰到此类问题, 请自行略过.


问题


先看一张效果图 (图1):

image.png

两个网图, 同样设置的笔画宽度为1 setStrokeWidth(1), 左边的显示的大小是正常的, 右边则变成了2. 颜色也淡了.

下面这张图看起来会很明显,(一个方格为一个PIXEL) (图2):

image.png

而程序设计时, 所期望的效果是: (图3):

image.png


WHY


大概也猜到了, 这可能跟设置了抗锯齿有关, 没错, 确实的这样子


Paint paint;
        Paint paintAnti;
        @Override
        protected void onSizeChanged(int w, int h, int oldw, int oldh) {
            super.onSizeChanged(w, h, oldw, oldh);
            //无抗锯齿
            paint = createPaint(false, Color.GREEN);
            //设置了抗锯齿
            paintAnti = createPaint(true, Color.RED);
        }
        Paint createPaint(boolean anti, int color){
            Paint paint = new Paint(anti ? Paint.ANTI_ALIAS_FLAG : 0);
            paint.setColor(color);
            paint.setStyle(Paint.Style.STROKE);
            //设置同样的宽度.
            paint.setStrokeWidth(1);
            return paint;
        }


创建画笔的唯一区别就是设置了Paint.ANTI_ALIAS_FLAG, 那么这个问题其实很好解决, 把抗锯齿关了就可以了.


确实是这样.


继续


同样上面的红网模糊的代码, 加入一个功能, 通过触摸更新红网的位置,


//添加直线.
        void addLine(Path p, float fx, float fy, float tx, float ty){
            p.moveTo(fx + startX, fy + startY);
            p.lineTo(tx + startX, ty + startY);
        }
  //更新Path.
        void update(){
            pathAnti.reset();
            float left = 60;
            float right = 110;
            float top = 0;
            float bottom = 0;
            for(int i = 1; i < 10; i ++) {
                top = bottom = i * interval;
                addLine(pathAnti, left, top, right, bottom);
            }
            top = 0;
            bottom = 50;
            for(int i = 1; i < 10; i ++) {
                left = right = 60 + i * interval;
                addLine(pathAnti, left, top , right, bottom);
            }
        }
        float startX, startY;
        @Override
        public boolean onTouchEvent(MotionEvent event) {
            startX = event.getX()/30f;
            startY = event.getY()/30f;
            update();
            postInvalidate();
            return true;
        }


通过不停的触摸不同的位置并观察红网的效果, 发现一个现象,

当startX/startY的值, 去掉整数后, 剩下的小数值, 越接近0.5, 则线越实, 越接近期望的效果.


最接近期望效果 图4


image.png


于是, addLine稍微修改下:


void addLine(Path p, float fx, float fy, float tx, float ty){
          //取整, 再加上0.5, 得到的结果永远是 x.5;
            fx = (int)(fx + startX) + 0.5f;
            tx = (int)(tx + startX) + 0.5f;
            fy = (int)(fy + startY) + 0.5f;
            ty = (int)(ty + startY) + 0.5f;
            p.moveTo(fx, fy);
            p.lineTo(tx, ty);
        }


不管如何更新坐标, 显示的效果都如下图: 图5

image.png


DashPathEffect dpe = new DashPathEffect(new float[]{3, 4}, 0);
            paint.setPathEffect(dpe);
            paintAnti.setPathEffect(dpe);


画个虚线 图6

image.png


最后


有点遗憾问题并不能够完美解决. 要能够彻底弄清楚是何原理, 估计得花不少精力去研究系统源码, 暂时没这时间精力, 只能听之任之, 坐等精于此道的先行者指点谜津. 共勉!


相关实践学习
使用PAI-EAS一键部署ChatGLM及LangChain应用
本场景中主要介绍如何使用模型在线服务(PAI-EAS)部署ChatGLM的AI-Web应用以及启动WebUI进行模型推理,并通过LangChain集成自己的业务数据。
机器学习概览及常见算法
机器学习(Machine Learning, ML)是人工智能的核心,专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能,它是使计算机具有智能的根本途径,其应用遍及人工智能的各个领域。 本课程将带你入门机器学习,掌握机器学习的概念和常用的算法。
相关文章
|
编解码 Android开发
Android Paint ANTI_ALIAS_FLAG 引起的一个小问题
Android Paint ANTI_ALIAS_FLAG 引起的一个小问题
213 0
Android Paint ANTI_ALIAS_FLAG 引起的一个小问题
|
前端开发 Android开发 Python
|
前端开发 Android开发 图形学
Android自定义View工具:Paint&Canvas(一)
本文主要讲的是自定义View时我们经常用到的Canvas和Paint,像平时画画一样,我们需要画布和画笔,而Canvas就是画布,Paint就是画笔
108 0
|
API Android开发
android自定义控件-paint详解
android自定义控件-paint详解
379 0
android自定义控件-paint详解
|
vr&ar Android开发
【Android 应用开发】Paint 图形组合 Xfermod 之 合成模式表示方法 ( Xfermod 使用步骤 | 透明度 颜色值 公式表示方法 | 老版本表示方法 | 合成区域分块 )
【Android 应用开发】Paint 图形组合 Xfermod 之 合成模式表示方法 ( Xfermod 使用步骤 | 透明度 颜色值 公式表示方法 | 老版本表示方法 | 合成区域分块 )
231 0
【Android 应用开发】Paint 图形组合 Xfermod 之 合成模式表示方法 ( Xfermod 使用步骤 | 透明度 颜色值 公式表示方法 | 老版本表示方法 | 合成区域分块 )
|
Android开发 图形学
【Android 应用开发】Paint 图形组合 Xfermod 简介 ( 图形组合集合描述 | Xfermod 简介 | PorterDuff 简介 )
【Android 应用开发】Paint 图形组合 Xfermod 简介 ( 图形组合集合描述 | Xfermod 简介 | PorterDuff 简介 )
174 0
【Android 应用开发】Paint 图形组合 Xfermod 简介 ( 图形组合集合描述 | Xfermod 简介 | PorterDuff 简介 )
|
Android开发
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(二)
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(二)
319 0
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(二)
|
前端开发 Android开发
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(一)
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(一)
431 0