博客
关于我
自定义绘制View常用方法
阅读量:534 次
发布时间:2019-03-08

本文共 1671 字,大约阅读时间需要 5 分钟。

继承与View
class MyView: View {}
//代码实现,当使用代码创建该视图时调用该方法     constructor(context: Context) : super(context) {}   //xml实现,当使用xml方式创建该视图时调用该方法     constructor(context: Context,attributeSet: AttributeSet) : super(context,attributeSet){}
三:若需要获取视图的size则在OnSizeChanged()中获取     当视图的大小发生改变时调用该方法
override fun onSizeChanged(w: Int, h: Int, oldw: Int, oldh: Int) {       super.onSizeChanged(w, h, oldw, oldh)     }
四:绘制图片    绘制图片在ondraw方法中实现
//在该方法中绘制主要的内容     override fun onDraw(canvas: Canvas?) {         super.onDraw(canvas)       }     //在该方法中绘制子视图的内容
override fun dispatchDraw(canvas: Canvas?) {       super.dispatchDraw(canvas)     }
//绘制前景     override fun onDrawForeground(canvas: Canvas?) {         super.onDrawForeground(canvas)       }     五:绘制的方法     drawColor 颜色     drawCircle 圆形     drawRect 矩形     drawPoint 点     drawOval 椭圆     drawLine 线     drawRoundRect 圆⻆矩形     drawArc 弧形     drawPath 自定义路径     drawBitmap 绘图     drawText 文字     drawTextOnPath 在路径上绘制     StaticLayout 多行文字绘制     以路劲为例:
canvas?.drawPath(path,paint1)     Path():  
Path().apply {       moveTo(0f,0f) //路径的开头的位置       lineTo(0f,500f) //画一条线的结束位置       cubicTo(100f,0f,300f,1000f,400f,500f)//三阶贝塞尔曲线     }  
arcTo 弧形 close 闭合
     Paint().apply {       //画笔的颜色       color = Color.BLACK       //样式       style = Paint.Style.STROKE       //笔的宽度       strokeWidth = 10f     }
LinearGradient 线性渐变
BitmapShader
ComposeShader
RadialGradient
SweepGradient

转载地址:http://nkxiz.baihongyu.com/

你可能感兴趣的文章
Pandas 中的日期范围
查看>>
pandas 中的时间序列箱线图
查看>>
Pandas 使用指南
查看>>
pandas 分组并使用最小值更新
查看>>
Pandas 对数据框的布尔比较
查看>>
pandas 将通话数据分割为15分钟的间隔
查看>>
pandas 找到局部最大值和最小值
查看>>
pandas 时间序列重新采样结束给定的一天
查看>>
pandas 根据不是常量的第三列的值将值从一列复制到另一列
查看>>
pandas 根据值从多列中的一列查找
查看>>
Pandas 根据布尔条件选择行和列
查看>>
pandas 滚动窗口 - datetime64[ns] 未实现
查看>>
pandas 版本兼容特定的蟒蛇和NumPy配置吗?
查看>>
pandas 生成excel多级表头
查看>>
pandas 读取excel数据,以字典形式输出
查看>>
Pandas 读取具有浮点值的 csv 文件会导致奇怪的舍入和小数位数
查看>>
pandas 适用,但仅适用于满足条件的行
查看>>
pandas 重新采样到每月的特定工作日
查看>>
pandas :按移位分组和累加和(GroupBy Shift And Cumulative Sum)
查看>>
pandas :检测一个DF和另一个DF之间缺失的列
查看>>