转载请注明出处王亟亟的大牛之路

之前也有一个相似于画板的操作,可是不够具体,这边先补上链接。有兴趣的小伙伴能够看看http://blog.csdn.net/ddwhan0123/article/details/48804761

还是老规矩,将内容之前说下我们的一些知识点。今天的第一个知识点有点高DA上的名词“硬件加速”。

硬件加速:

问题1:这玩意有什么用?

在绘制View的时候支持硬件加速。充分利用GPU的特性,使得绘制更加平滑。

问题2:怎么用?

在AndroidManifest的Application 或者Activity节点<application android:hardwareAccelerated="true/false">就能够进行开关。

或者用Java代码:getWindow().setFlags(WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED, WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED);

假设这些你都不喜欢。你仅仅要那个类其中的某个View是对这部分功能有需求的。那么这样:view.setLayerType(View.LAYER_TYPE_SOFTWARE, null); 可是要记住Window仅仅能打开。View仅仅能关闭所以还是在Activity和Application层面操作吧。

问题3:非用不可吗?

假设你的View的绘制内容比較复杂,比較对多,还是建议开着,诸如画密度非常细的那种虚线或者颜色区域超级复杂的一些试图的画还是开着吧,不然说不定你再挂个什么网络的操作万一客户机烂一点一个未响应提示就来了。

Paint:

这部分的内容就不提了。网上多如牛毛。贴一个写的比較简单易通的http://www.cnblogs.com/tianzhijiexian/p/4297170.html?

utm_source=tuicool&utm_medium=referral

http://www.kancloud.cn/kancloud/android-tutorial/87246

Canvas:

如上,还是附上可參考的链接:http://blog.sina.com.cn/s/blog_61ef49250100qw9x.html

http://www.kancloud.cn/kancloud/android-tutorial/87261

性能优化(跟自己定义画图相关的):

1.设置缓存:View 中设置缓存属性.setDrawingCache为true

2.优化布局:tools文件夹下的layoutopt 命令

3.将Acitivity 中的Window 的背景图设置为空(默认不为空)。getWindow().setBackgroundDrawable(null);

4.採用SurfaceView在子线程刷新UI,:避免手势的处理和绘制在同一UI线程(普通View都这样做)。

5:採用JNI:将耗时间的处理放到c/c++层来处理。


主要来说下自己定义控件重要的三个方法“onMeasure()”。“onDraw()”,“onLayout()”:

1.onMeasure()方法就是用于測量视图的大小的,不然你的空间永远都仅仅是白屏,不是没画上去,而是没有尺寸。

measure()方法接收两个參数。widthMeasureSpec和heightMeasureSpec也就是宽度和长度。

MeasureSpec的值由specSize和specMode共同组成的,specSize是大小,specMode是规格。

有三种规格:1. EXACTLY,AT_MOST,UNSPECIFIED。这三种规格细说太复杂了,我整合给大家听下

(1):子视图的大小应该是由specSize的值来决定,用户也可自行定义

(2):子视图最多仅仅能是specSize中指定的大小。仅仅能更小不能更大了

(3):能够将视图依照自己的意愿设置成随意的大小,没有不论什么限制

当rootDimension參数等于MATCH_PARENT的时候,MeasureSpec的specMode就等于EXACTLY。当rootDimension等于WRAP_CONTENT的时候,MeasureSpec的specMode就等于AT_MOST。而且MATCH_PARENT和WRAP_CONTENT时的specSize都是等于windowSize的。也就意味着根视图总是会充满全屏的。

这里的rootDimension是根布局的尺寸

总结:视图大小的控制是由父视图、布局文件、以及视图本身共同完毕的,父视图会提供给子视图參考的大小。而开发者能够在XML文件里指定视图的大小,然后视图本身会对终于的大小进行拍板。

不然就会出现onCreate时发现控件宽高都是0。之前有提到。看这里http://blog.csdn.net/ddwhan0123/article/details/50386685

2.onLayout()用于给视图进行布局的,也就是确定视图的位置。会在onMeasure方法之后运行。

layout()方法接收四个參数,分别代表着左、上、右、下的坐标。当然这个坐标是相对于当前视图的父视图而言的。

像这样layout(0, 0, host.mMeasuredWidth, host.mMeasuredHeight);

可是画图的位置操作我们能够在onDraw里运行,所以假设你不想了解这部分,这方法你不調用都行,可是要记得在画的时候重现位置特性。不然就是“一坨屎在一起了”

3.onDraw(),measure和layout的过程都结束后。接下来就进入到这种方法了。我们全部的作画的事,都在这干!

ViewRoot中的代码会继续运行并创建出一个Canvas对象,然后调用View的draw()方法来运行具体的绘制工作

我们的绘画都是在这个Canvas对象的支持下实现的,简单写个样例。

public class TestView extends View {
Paint paint;
Context context; public TestView(Context context) {
super(context);
this.context = context;
} public TestView(Context context, AttributeSet attrs) {
super(context, attrs);
init(context, attrs);
} public TestView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init(context, attrs);
} @TargetApi(Build.VERSION_CODES.LOLLIPOP)
public TestView(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
super(context, attrs, defStyleAttr, defStyleRes);
init(context, attrs);
} private void init(Context context, AttributeSet attrs) {
paint = new Paint();
// paint.setColor(getResources().getColor(R.color.SlateBlue));
paint.setColor(getResources().getColor(R.color.Gold));
paint.setStrokeWidth(3);
} @Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
Log.d("--->onDraw", "onDraw()");
// canvas.drawCircle(0, 0, 90, paint);
canvas.drawCircle(100, 100, 90, paint);
} @Override
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
super.onLayout(changed, left, top, right, bottom);
Log.d("--->onLayout", "changed = " + changed + " left = " + left + " top = " + top + " right = " + right + " bottom " + bottom);
} @Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
Log.d("--->onMeasure", " widthMeasureSpec =" + widthMeasureSpec + " heightMeasureSpec = " + heightMeasureSpec);
setMeasuredDimension(widthMeasureSpec, heightMeasureSpec);
}
}

凝视部分运行效果:

现有代码效果:

打印的顺序

请细致看onLayout()的那些坐标,他任然保持着父布局的一系列属性參数:

  android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"

相关资源收集:http://blog.csdn.net/michaelcao1980/article/details/43233909

自己定义View时,用到Paint Canvas的一些温故,讲讲平时一些效果是怎么画的(基础篇 一)的更多相关文章

  1. 自己定义View时,用到Paint Canvas的一些温故,简单的帧动画(动画一 ,&quot;掏粪男孩Gif&quot;顺便再提提onWindowFocusChanged)

    转载请注明出处:王亟亟的大牛之路 之前在绘画的过程中提到了静态的旋转啊,缩放啊,平移等一些效果.那么自己定义的View当然也有动态的效果也就是我们的Animation.经常使用的有三种 View An ...

  2. 自己定义 View 基础和原理

    课程背景: 在 Android 提供的系统控件不能满足需求的情况下,往往须要自己开发自己定义 View 来满足需求,可是该怎样下手呢.本课程将带你进入自己定义 View 的开发过程,来了解它的一些原理 ...

  3. 【Android】自己定义View、画家(画布)Canvas与画笔Paint的应用——绘图、涂鸦板app的实现

    利用一个简单的绘图app来说明安卓的图形处理类与自己定义View的应用. 例如以下图,有一个供用户自己随意绘图.涂鸦的app. 这里不做那么花俏了,仅提供黑白两色.但能够改变笔尖的粗细. 实质上这里的 ...

  4. 安卓自己定义View进阶-Canvas之绘制基本形状

    Canvas之绘制基本形状 作者微博: @GcsSloop [本系列相关文章] 在上一篇自己定义View分类与流程中我们了解自己定义View相关的基本知识,只是,这些东西依然还是理论,并不能拿来(zh ...

  5. 转载爱哥自定义View系列--Paint详解

    上图是paint中的各种set方法 这些属性大多我们都可以见名知意,很好理解,即便如此,哥还是带大家过一遍逐个剖析其用法,其中会不定穿插各种绘图类比如Canvas.Xfermode.ColorFilt ...

  6. Android 它们的定义View (一)

    转载请注明出处:http://blog.csdn.net/lmj623565791/article/details/24252901 非常Android入门程序员AndroidView.可能都是比較恐 ...

  7. Android自定义View研究--View中的原点坐标和XML中布局自定义View时View触摸原点问题

    这里只做个汇总~.~独一无二 文章出处:http://blog.csdn.net/djy1992/article/details/9715047 Android自定义View研究--View中的原点坐 ...

  8. Android 它们的定义View它BounceProgressBar

    转载请注明出处:http://blog.csdn.net/bbld_/article/details/41246247 [Rocko's blog] 之前几天下载了非常久没用了的桌面版酷狗来用用的时候 ...

  9. 图文剖析自己定义View的绘制(以自己定义滑动button为例)

    自己定义View一直是横在Android开发人员面前的一道坎. 一.View和ViewGroup的关系 从View和ViewGroup的关系来看.ViewGroup继承View. View的子类.多是 ...

随机推荐

  1. Linux网络编程一步一步学【转】

    转自:http://blog.chinaunix.net/uid-10747583-id-297982.html Linux网络编程一步一步学+基础  原文地址:http://blogold.chin ...

  2. linux c/c++ 代码使用 doxygen 自动生成文档

    www.doxygen.org 的使用非常方便,下面分成2步介绍一下 1. 注释风格,需要在c/c++代码中按照下面的风格添加注释,基本上还是很顺手的 C++的注释风格 主要使用下面这种样式:即在注释 ...

  3. Leap Motion颠覆操控体验的超精致手势追踪技术【转】

    转自:http://www.cnblogs.com/emouse/archive/2013/02/28/2936689.html 先来看两段简介视频: 看了介绍视频后,对如此次超高精度的手势追踪非常好 ...

  4. 数据库--MyBatis的(insert,update,delete)三种批量操作

    转自:http://blog.csdn.net/starywx/article/details/23268465 前段时间由于项目赶期没顾上开发过程中的性能问题,现对部分代码进行优化的过程中发现在数据 ...

  5. springBoot springCloud

    微服务功能的主要体现: 1)服务的注册与发现 Eureka ,Consul ,Zookeeper 2)服务的负载均衡 Ribbon 3)服务的容错 Hystrix 4)服务的网关 微服务中常用的网关组 ...

  6. 计蒜客 28206.Runway Planning (BAPC 2014 Preliminary ACM-ICPC Asia Training League 暑假第一阶段第一场 F)

    F. Runway Planning 传送门 题意简直就是有毒,中间bb一堆都是没用的,主要的意思就是度数大于180度的就先减去180度,然后除以10,四舍五入的值就是答案.如果最后结果是0就输出18 ...

  7. codeforces-526B

    题目连接:http://codeforces.com/contest/526/problem/B B. Om Nom and Dark Park time limit per test 1 secon ...

  8. NYOJ16 矩形嵌套 【DAG上的DP/LIS】

    矩形嵌套 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 有n个矩形,每个矩形可以用a,b来描述,表示长和宽.矩形X(a,b)可以嵌套在矩形Y(c,d)中当且仅当a<c ...

  9. Python的支持工具[1] -> 可执行文件生成工具[1] -> cx_freeze

    cx_freeze cx_Freeze 是一个第三方库,可以用于将 Python 的代码打包成可执行文件,下面介绍如何利用一个脚本文件将 Python 代码变为 exe 可执行文件. 首先,需要安装 ...

  10. 物理像素,ppi,逻辑分辨率和物理分辨率

    1 明确几个概念: 物理像素:屏幕物理像素 屏幕像素密度ppi:pixels per inch,屏幕上每英寸可以显示的像素点的数量,即屏幕像素密度.顺便一提,ppi就是dpi,只不过有文章里说苹果喜欢 ...