IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> Android Paint ANTI_ALIAS_FLAG 引起的一个小问题 -> 正文阅读

[移动开发]Android Paint ANTI_ALIAS_FLAG 引起的一个小问题

平台

RK3399 + Android 8.1

问题

代码中, 屏幕分辨率为1024x600, 自定义View的尺寸为300x300, 在窗口居中显示.
自定义View绘制的顺序为:

  1. 绘制白色背景-Canvas.drawColor
  2. 绘制黑色矩形-Canvas.drawRect
  3. 绘制红色交叉线, 分别为左上-右下 和 右上-左下 两条
  4. 绘制四个角圆, 半径为10个像素

效果图:
在这里插入图片描述
在代码中,增加了左右拖动旋转控件的功能
在这里插入图片描述


在这里插入图片描述
上图的虚线, 非代码绘制

在没有旋转控件前, 并未出现图中的虚线, 而且虚线还会根据旋转的角度而产生变化, 虚线的颜色会根据自定义View的背景色发生改变.

源码

canvas_test.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/rlRoot"
    android:background="#FF000000"/>

CanvasTest.java

package com.android.test;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.RectF;
import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.widget.RelativeLayout;

import com.android.test.R;

public class CanvasTest extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.canvas_test);
        RelativeLayout rlRoot = (RelativeLayout)findViewById(R.id.rlRoot);
        CanvasView cv = new CanvasView(this);
        RelativeLayout.LayoutParams lp = new RelativeLayout.LayoutParams(300, 300);
        lp.addRule(RelativeLayout.CENTER_IN_PARENT);
        rlRoot.addView(cv, lp);
    }

    class CanvasView extends View {

        Paint p_anti = new Paint(Paint.ANTI_ALIAS_FLAG);
        Paint p_norm = new Paint();

        public CanvasView(Context context) {
            super(context);
        }

        int W, H;
        int CX, CY;
        RectF viewPort = new RectF();
        @Override
        protected void onSizeChanged(int w, int h, int oldw, int oldh) {
            super.onSizeChanged(w, h, oldw, oldh);
            W = w;
            CX = W/2;
            H = h;
            CY = H/2;

            viewPort.set(0, 0, W, H);
        }

        float dx, dy, cx, cy;
        float rotZ = 0;
        @Override
        public boolean onTouchEvent(MotionEvent event) {
            float x = event.getRawX();
            float y = event.getRawY();
            cx = x;
            cy = y;
            switch(event.getAction()){
                case MotionEvent.ACTION_DOWN:
                    dx = x;
                    dy = y;
                    rotZ = getRotation();
                    break;
                case MotionEvent.ACTION_MOVE:
                    float rotate = (dx - cx) / W;
                    setRotation(rotZ + 90f * rotate);
                    break;

            }
            return true;
        }

        @Override
        protected void onDraw(Canvas canvas) {
            Paint p = p_anti;
            canvas.drawColor(Color.WHITE);

            //RECT
            p.setColor(Color.BLACK);
            canvas.drawRect(viewPort, p);

            //LINES
            p.setColor(Color.RED);
            float[] lines = {viewPort.left, viewPort.top, viewPort.right, viewPort.bottom,
                            viewPort.right, viewPort.top, viewPort.left, viewPort.bottom};
            canvas.drawLines(lines, p);

            //CIRCLE
            for(int i = 0; i < lines.length / 2; i ++){
                canvas.drawCircle(lines[i * 2], lines[i * 2 + 1], 10, p);
            }
        }
    }
}

最终发现, 这是由Paint引起的.
在代码中定义了两个Paint

        Paint p_anti = new Paint(Paint.ANTI_ALIAS_FLAG);
        Paint p_norm = new Paint();

在onDraw函数中, 使用p_norm并不会出现虚线的问题, 而使用p_anti才会出现.
放大图像:
在这里插入图片描述

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-08-20 15:14:29  更:2021-08-20 15:15:21 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 10:13:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码