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 重写TextView的onDraw函数遇坑记 -> 正文阅读

[移动开发]Android 重写TextView的onDraw函数遇坑记

平台

RK3288 + Android 7.1 + Android Studio Chipmunk | 2021.2.1

问题

重写也TextView, 尝试在onDraw中绘制一些图形时不能正确显示出来.
比如, 给TextView 增加下个蓝色边框, 再绘制一条从左上到右下的绿色直线
在这里插入图片描述
然而, 实际的效果却是
在这里插入图片描述

根源及解决方法

先看下代码:

import android.app.Activity;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.os.Bundle;
import android.util.AttributeSet;
import android.util.Log;
import android.view.Gravity;
import android.view.View;
import android.widget.TextView;

public class TextViewTest extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        final XTextView tv = new XTextView(this);
        tv.setTextSize(32);
        tv.setTextColor(Color.RED);
        tv.setText("Test");
        tv.setSingleLine(true);
        tv.setGravity(Gravity.CENTER);
        tv.setTag(0);
        setContentView(tv);
    }

    static class XTextView extends TextView {

        Paint mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
        int W, H;

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

        public XTextView(Context context, AttributeSet attrs) {
            super(context, attrs);
        }

        public XTextView(Context context, AttributeSet attrs, int defStyleAttr) {
            super(context, attrs, defStyleAttr);
        }

        @Override
        protected void onSizeChanged(int w, int h, int oldw, int oldh) {
            super.onSizeChanged(w, h, oldw, oldh);
            W = w;
            H = h;
        }

        @Override
        protected void onDraw(Canvas canvas) {
            super.onDraw(canvas);
            //draw line leftTop to rightBottom
            mPaint.setStyle(Paint.Style.STROKE);
            mPaint.setColor(Color.GREEN);
            mPaint.setStrokeWidth(2);
            canvas.drawLine(0, 0, W, H, mPaint);

            //draw rect for view.
            mPaint.setColor(Color.BLUE);
            canvas.drawRect(0, 0, W, H, mPaint);
        }
    }
}

问题的根源就在于这两行代码:

        tv.setSingleLine(true);
        tv.setGravity(Gravity.CENTER);

google 后, 在Canvas.drawRect is not work in TextView’s onDraw when set gravity中发现了同样的问题.

SingleLineGravity.CENTER同时出现设置后, 会出现上面的问题, 尝试注释
tv.setSingleLine(true);

tv.setGravity(Gravity.CENTER);

确实可以解决这个问题.

PS: 除了Gravity.CENTER, Gravity.CENTER_HORIZONTAL 同样会引起这个问题

解决方法, 在前面的链接中已经有提及.
在这里插入图片描述
另一种方法: 通过canvas.getClipBounds(bound); 获取视窗的坐标.

        Rect bound = new Rect();
        @Override
        protected void onDraw(Canvas canvas) {
            super.onDraw(canvas);
            //get bound for viewport
            canvas.getClipBounds(bound);
            Log.d("XTextView", "onDraw " + getText() + ":" + bound.toShortString());
            Log.d("XTextView", "onDraw " + getText() + ":" + getScrollX() + "," + getScrollY());

            //draw line leftTop to rightBottom
            mPaint.setStyle(Paint.Style.STROKE);
            mPaint.setColor(Color.GREEN);
            mPaint.setStrokeWidth(2);
            canvas.drawLine(bound.left, bound.top, bound.right, bound.bottom, mPaint);

            //draw rect for view.
            mPaint.setColor(Color.BLUE);
            canvas.drawRect(bound, mPaint);
            //canvas.drawRect(bound, mPaint);
        }

参考

Canvas.drawRect is not work in TextView’s onDraw when set gravity

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-05-18 17:46:02  更:2022-05-18 17:46:41 
 
开发: 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/25 1:51:25-

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