自定义View (三) :onDraw 之 paint 画笔

前两篇我们讲了自定义View的onMeassure 的方法以及一个相对简单的例子。我们回顾下:
1.测量 —— onMeasure() :决定View的大小。
2. 布局 —— onLayout() :决定View在ViewGroup中的位置。
3. 绘制 —— onDraw() : 如何绘制这个View
而 measureSpec 的三中mode 我们也要搞清楚。
  1.UNSPECIFIED  
  父不没有对子施加任何约束,子可以是任意大小(也就是未指定)  
  (UNSPECIFIED在源码中的处理和EXACTLY一样。当View的宽高值设置为0的时候或者没有设置宽高时,模式为UNSPECIFIED  
  2.EXACTLY  
  父决定子的确切大小,子被限定在给定的边界里,忽略本身想要的大小。  
  (当设置width或height为match_parent时,模式为EXACTLY,因为子view会占据剩余容器的空间,所以它大小是确定的)  
  3.AT_MOST  
  子最大可以达到的指定大小  
  (当设置为wrap_content时,模式为AT_MOST, 表示子view的大小最多是多少,这样子view会根据这个上限来设置自己的尺寸)   
我们可以 结合具体的例子,这样更好理解: http://blog.csdn.net/lijinweii/article/details/72850964

那么我们为什么在自定义View中不介绍onLayout方法呢?(借用同事的一句话)其实对于自定义View来说,onLayout方法基本上不用重写,但是对于自定义ViewGroup而言,此方法确实相当的重要,因为他要计算出viewGroup中所有的子view。

1.onDraw之paint 画笔

在探究onDraw之前首先必须要认识两个类,这里给出非常不错的两个资料参考网站,我也是从这里得到想要知道的东西

http://blog.csdn.net/abcdef314159/article/details/51720686 

http://www.apihome.cn/api/android/Paint.html

http://www.cnblogs.com/aibuli/p/efef9d774df97c553a8a0c0c3495ba35.html?utm_source=tuicool&utm_medium=referral 

http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2014/1105/1907.html

http://blog.csdn.net/harvic880925/article/details/39080931

这里的方法已经很详细了,我们简单的挑几个常用的看看。

1.set(paint src)

  复制一个画笔

2.setAntiAlias(boolean aa)

设置抗锯齿。如果不设置,加载位图的时候可能会出现锯齿状的边界,如果设置,边界就会变的稍微有点模糊,锯齿就看不到了。

3.setAlpha(int a)

设置透明度

4.setColor(int color)

设置颜色值

5.setStyle(Paint.Style style)

置画笔样式,如果不设置,默认是全部填充(FILL)。可选项为:FILL(填充)、FILL_AND_STROKE(描边并填充)、STROKE(描边)

6.setTextSize(float textSize)

设置文字大小

7.setTextAlign(Paint.Align align)

设置文本对齐方式。CENTER,LEFT和RIGHT

8.setStrokeWidth(float width)

当画笔样式(style)为STROKE或FILL_OR_STROKE时(空心样式时),设置笔刷的粗细度。

9.setShadowLayer(float radius, float dx, float dy, int color)

设置阴影效果
radius表示阴影的扩散半径;dx和dy表示阴影平面上的偏移值;shadowColor就不说了阴影颜色。
注意: 这个方法不支持硬件加速,所以我们要测试时必须先关闭硬件加速。

还有很多,我就不一  一 列举了。其实我们平时常用到的方法很少,一些比较冷的方法压根就用不到.

        mPaint = new Paint();
        mPaint.setAntiAlias(true);//设置抗锯齿
        mPaint.setStyle(Paint.Style.STROKE);//设置格式为描边
        mPaint.setColor(Color.BLACK);//设置颜色
        mPaint.setStrokeWidth(10);//设置描边宽度

但是还有一点需要大家注意:

但是要注意一点,最好不要在onDraw方法中new Paint();
因为onDraw方法有可能会多次调用,(官方给出了invalidate();和postInvalidate();里面调用了onDraw方法。)多次的new 对象,容易影响内存的消耗.大笑这句话是我借用同事的。

另外请参考:http://blog.csdn.net/sinat_26710701/article/details/70156361

http://www.cnblogs.com/yishujun/p/5559917.html


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android 中的 Paint 类可以用来绘制各种形状和线条。下面是一个简单的示例,演示如何使用 Paint 类在 Android 中绘制直线。 首先,在 XML 布局文件中添加一个 View: ```xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/layout" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <View android:id="@+id/drawing_view" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1" /> </LinearLayout> ``` 然后,在 Activity 中获取该 View 并绘制直线: ```java public class MainActivity extends AppCompatActivity { private View drawingView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); drawingView = findViewById(R.id.drawing_view); drawingView.setBackground(new CustomView(this)); } private class CustomView extends View { private Paint paint; public CustomView(Context context) { super(context); init(); } private void init() { paint = new Paint(); paint.setColor(Color.RED); paint.setStrokeWidth(5f); } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); int startX = 0; int startY = 0; int stopX = getWidth(); int stopY = getHeight(); canvas.drawLine(startX, startY, stopX, stopY, paint); } } } ``` 在这个示例中,我们创建了一个 CustomView 类,继承自 View 类,并在该类中实现了 onDraw() 方法onDraw() 方法用于绘制 View 上的内容,我们在这里使用 Canvas 类的 drawLine() 方法绘制了一条直线。 Paint 类的实例被创建在 CustomView 类的构造函数中,我们使用该实例设置了直线的颜色和线宽。如果需要绘制其他形状,也可以使用 Paint 类的其他方法来设置笔刷、阴影、渐变等效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值