Android View 如何绘制

  上文说道了Android如何测量,但是一个漂亮的控件我只知道您长到哪儿,这当然不行。只需要简单重写OnDraw方法,并在Canvas(画布)对象上调用那根五颜六色的画笔就能够画出这控件"性感"的外表。那么View又是如何进行绘制了?

  要了解View如何绘制,就需要了解canvas(画布)是什么?paint(画笔)能够做什么。

  Ⅰ、canvas就是表示一块画布,你可以在上面画你所朝思暮想的东西。当我们重写onDraw方法的时候,就能够拿到一个Canvas对象,这个就是你的舞台,画你所思所想。上代码了。

 

@Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
    }

   当您需要对某某控件进行进行重新绘制的时候,我们只需要在这个大舞台(Canvas)调用Canvas.DrawXXX方法画出各种各样的图形。

  Ⅱ、paint就是画布上挥洒自如的画笔。要画图,得调整画笔,待画笔调整好之后,再将图像绘制到画布上,这样才可以显示在手机屏幕上。Paint上提供许多属性和方法用来设置画笔。

  1、setAntiAlias: 设置画笔的锯齿效果。 
  2、setColor: 设置画笔颜色 
  3、setARGB:  设置画笔的a,r,p,g值。 
  4、setAlpha:  设置Alpha值 
  5、setTextSize: 设置字体尺寸。 
  6、setStyle:  设置画笔风格,空心或者实心。 
  7、setStrokeWidth: 设置空心的边框宽度。 
  8、getColor:  得到画笔的颜色 
  9、getAlpha:  得到画笔的Alpha值。

  我们既然知道了画笔与画布,通过一个短小精悍的例子来看画布和画笔怎么共同作用出一个想要的图形。老样子,上代码:

public class MyView extends View {

    private Paint paint;
    public MyView(Context context, AttributeSet attrs) {
        super(context, attrs);
        init();
    }

    private void init() {
        paint=new Paint(Paint.ANTI_ALIAS_FLAG);
        paint.setColor(Color.RED);
        paint.setStrokeWidth(5);
        paint.setTextSize(28);

    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        setMeasuredDimension(measureWidth(widthMeasureSpec),
                measureWidth(heightMeasureSpec));
    }

    public int measureWidth(int measureSpec) {
        int result = 0;
        int specMode = MeasureSpec.getMode(measureSpec);
        int specSize = MeasureSpec.getSize(measureSpec);
        if (specMode == MeasureSpec.EXACTLY) {
            result = specSize;
        } else {
            result = 200;
            if (specMode == MeasureSpec.AT_MOST) {
                result = Math.min(specSize, result);
            }
        }
        return result;
    }

    @Override
    protected void onDraw(Canvas canvas) {
        canvas.drawText("中国", 0, 80, paint);
        super.onDraw(canvas);
    }
}

  上述代码,我们做了这么几件事了:

  Ⅰ、我们运用上篇文章的知识,重写了onMeasure方法,让这个简单自定义控件自适应wrap_content属性。

  Ⅱ、我们调用了OnDraw方法,拿到Canvas与paint,在view上写了"中国"文字。

  最终运行效果为:

  这就是我对Android View 如何绘制一点灼见,本人才疏学浅,欢迎大家斧正。

时间: 2024-10-06 03:36:44

Android View 如何绘制的相关文章

Android View的绘制流程

View 绘制机制 1. View 树的绘图流程 当 Activity 接收到焦点的时候,它会被请求绘制布局,该请求由 Android framework 处理.绘制是从根节点开始,对布局树进行 measure 和 draw.整个 View 树的绘图流程在ViewRoot.java类的performTraversals()函数展开,该函数所做 的工作可简单概况为是否需要重新计算视图大小(measure).是否需要重新安置视图的位置(layout).以及是否需要重绘(draw),流程图如下: Vi

从源码角度分析Android View的绘制机制(一)

在Android的学习道路上,每一个人员都免不了去翻阅Android的源码,因为只有从源码的角度分析问题,我们才能真正的玩转Android开发.最近由于工作比较闲,总想着想写点什么东西,正好自己也可以整理一下.考虑到view的显示机制是自定义view的基础,也是面试中经常被问到的问题,所以记录此文,和大家共享,因水平有限,望大家踊跃拍砖,不胜感激. 有过自定义view的同行们都应该知道,view的显示依托于activity的setContentView方法依附到PhoneWindow窗体上的,在

Android View的绘制流程三部曲 —— Measure

在刚开始学习Java的时候,我看的是Mars老师的视频.Mars老师说过的一句话让我印象很深刻:要有一颗面向对象的心. 如果我们用面向对象的思维方式来思考,就会觉的View的绘制机制是很合理,很科学的.我们要在一张纸上画一幅画,首先要测量一下这幅画有多大吧,然后确定在这张纸的哪个地方画会显得比较美观,最后才是用画笔工具将画绘制在纸上. 在Android中也是一样的.View的绘制流程主要是指measure,layout,draw这三步,即测量,布局,绘制.首先是要测量View的宽高,然后布局确定

Android - View的绘制流程一(measure)

该博文所用的demo结构图: 相应的代码: MainActivity.java: [java] view plain copy <span style="font-family:Microsoft YaHei;">public class MainActivity extends Activity { private int desiredWindowWidth; private int desiredWindowHeight; @Override protected vo

Android View的绘制机制前世今生---前世

就像上个文章说的,触摸事件的传递机制是从外层到内层的过程. 我们想来看看这个页面里面的层级关系: 以下我们就用what-how-why三部曲的方式来分析View的绘制过程. 由于篇幅很大,所以分几篇来解析这个过程. 这篇主要是自定义view/viewgroup,以及从Activity到DecorView的加载过程. 1.what:怎么自定义一个View 1.1自定义View 自定义View的话,常见过程如下: /** * @author DemanMath * @date 2020-02-16

Android View的绘制

一.简介 当测量好了一个View之后,就可以简单的重写onDraw()方法,并在Canvas对象上来绘制所需要的图形.首先,我们来了解一下利用系统2D绘图API所必须要使用到的Canvas对象. 要在Android的界面中绘制相应的图像,就必须在Canvas上进行绘制.Canvas就像是画板,使用Paint就可以在上面作画.通常需要通过View并重写它的onDraw()方法来完成绘图.

Android - View的绘制你知道多少?

https://github.com/android-cn/android-open-project-analysis/tree/master/tech/viewdrawflow Android应用层View绘制流程与源码分析 Android-View的绘制源码学习总结 原文地址:https://www.cnblogs.com/qlky/p/10676093.html

android view的 绘制流程

韩梦飞沙  韩亚飞  [email protected]  yue31313  han_meng_fei_sha 首先是 从  视图根 这个类的  进行遍历 performTraversals 方法 开始, 然后 经过 测量,布局,绘制, 三个过程 将 视图 绘制出来. 测量  是 测量 视图的 宽高. 布局 是 确定 位置. 绘制 是  绘制.

Android View的绘制机制流程深入详解(二)