一对一视频app源码,Android 绘制渐变色

一对一视频app源码,Android 绘制渐变色实现的相关代码
一. 在xml文件中绘制
startColor:渐变色起始颜色

endColor:渐变色结束颜色

angle:绘制角度

代码:

复制代码
```handlebars
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<gradient
android:startColor="@color/colorStart"
android:angle="-45"
android:endColor="@color/colorEnd"/>
<size
android:width="@dimen/color_size"
android:height="@dimen/color_size"/>
<corners
android:radius="@dimen/radius"/>
</shape>
```
复制代码

 

二.在代码中绘制
重写ondraw方法,使用LinearGradient绘制渐变View

复制代码
```handlebars
override fun onDraw(canvas: Canvas?) {
if (mStartColor == null || mEndColor == null) {
return
}
val w: Float = measuredWidth.toFloat()
val h: Float = measuredHeight.toFloat()
val linearGradient =
LinearGradient(0f, 0f, w, h, mStartColor!!, mEndColor!!, Shader.TileMode.CLAMP)
val rectF = RectF(0f, 0f, w, h)
mPaint.shader = linearGradient
//角度从(0,0)到(w,h)的渐变色
canvas?.drawRoundRect(rectF, mRectRadius, mRectRadius, mPaint);
}
```
复制代码

 

三.绘制一组渐变色
把起始颜色和结束颜色定义在xml中:

复制代码
```handlebars
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string-array name="gradient_start">
<item>#2ae0c8 </item>
<item>#a2e1d4</item>
<item>#acf6ef</item>
<item>#cbf5fb</item>
<item>#bdf3d4</item>
<item>#e6e2c3</item>
<item>#e3c887</item>
<item>#fad8be</item>
<item>#fbb8ac</item>
<item>#fe6673</item>
<item>#2ae0c8 </item>
<item>#a2e1d4</item>
<item>#acf6ef</item>
<item>#cbf5fb</item>
<item>#bdf3d4</item>
<item>#e6e2c3</item>
<item>#e3c887</item>
<item>#fad8be</item>
<item>#fbb8ac</item>
<item>#fe6673</item>
</string-array>
<string-array name="gradient_end">
<item>#e3c887</item>
<item>#fad8be</item>
<item>#e3c887</item>
<item>#fad8be</item>
<item>#fe6673</item>
<item>#acf6ef</item>
<item>#EE8EBE</item>
<item>#a2e1d4</item>
<item>#acf6ef</item>
<item>#cbf5fb</item>
<item>#e3c887</item>
<item>#fad8be</item>
<item>#e3c887</item>
<item>#fad8be</item>
<item>#fe6673</item>
<item>#acf6ef</item>
<item>#EE8EBE</item>
<item>#a2e1d4</item>
<item>#acf6ef</item>
<item>#cbf5fb</item>
</string-array>
</resources>
```
复制代码

 

自定义一个布局,在布局中添加绘制的渐变色方块:

复制代码
```handlebars
private fun initColor() {
val startColor = resources.getStringArray(R.array.gradient_start)
val endColor = resources.getStringArray(R.array.gradient_end)
for (i in startColor.indices) {
val view = getView(Color.parseColor(startColor[i]), Color.parseColor(endColor[i]))
addView(view)
}
}
```
复制代码

 


以上就是,一对一视频app源码,Android 绘制渐变色实现的相关代码 更多内容欢迎关注之后的文章

posted @   云豹科技-苏凌霄  阅读(483)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示