Shader -> SweepGradient扫描渐变着色器详解

XML文件

xml 复制代码
<com.example.myapplication.MyView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_gravity="center"
    android:layout_height="400dp"/>

自定义View代码

kotlin 复制代码
class MyView @JvmOverloads constructor(
    context: Context, attrs: AttributeSet? = null, defStyleAttr: Int = 0
) : View(context, attrs, defStyleAttr) {

    private var mStartColor = Color.RED
    private var mMiddleColor = Color.BLUE
    private var mEndColor = Color.GREEN

    private var mDrawRect = RectF()
    private var mSweepGradient: SweepGradient? = null
    private var mDrawPaint = Paint()

    override fun onSizeChanged(w: Int, h: Int, oldw: Int, oldh: Int) {
        super.onSizeChanged(w, h, oldw, oldh)
        mDrawRect = RectF(0f, 0f, w.toFloat(), h.toFloat())
        mSweepGradient = SweepGradient(
            mDrawRect.centerX(), // 渐变中心的 x 坐标,设置为矩形中心的 x 坐标
            mDrawRect.centerY(), // 渐变中心的 y 坐标,设置为矩形中心的 y 坐标
            intArrayOf(mStartColor, mMiddleColor, mEndColor), // 渐变颜色数组
            floatArrayOf(0f, 0.5f, 1f) // 颜色位置数组
        )
    }

    override fun onDraw(canvas: Canvas) {
        super.onDraw(canvas)
        mSweepGradient?.let {
            mDrawPaint.shader = it
            canvas.drawRect(mDrawRect, mDrawPaint)
        }
    }
}

RadialGradient线性着色器参数详解

  • RadialGradient扫描渐变着色器赋值给Paint画笔,可以使用Canvas画布和Paint画笔绘制具有扫描渐变的内容,从渐变中心点开始顺时针旋转,进行扫描渐变

构造函数

  • 构造函数:多色渐变
java 复制代码
public SweepGradient(float cx, // 渐变中心的 x 坐标
                     float cy, // 渐变中心的 y 坐标
                     @NonNull int[] colors, // 渐变颜色数组
                     @Nullable float[] positions) // 颜色位置数组
  • cx, cy: 渐变中心的坐标
  • colors: 定义渐变的颜色数组,至少需要两个颜色
  • positions: 可选的颜色位置数组,定义每个对应颜色的相对位置(0 到 1 之间的浮点数)。如果为 null,颜色将在渐变中均匀分布

渐变中心点(x, y)只决定中心位置,映射方向按照顺时针旋转扫描绘制

颜色数组IntArray和位置数组FloatArray决定颜色的数量和位置

  • 起始颜色 mStartColor 和过渡颜色 mMiddleColor 只作用于 [0f, 0.5f] 这个区间
  • 过渡颜色 mMiddleColor 和结束颜色 mEndColor 只作用于 [0.5f, 1f] 这个区间
kotlin 复制代码
mSweepGradient = SweepGradient(
    mDrawRect.centerX(), // 渐变中心的 x 坐标,设置为矩形中心的 x 坐标
    mDrawRect.centerY(), // 渐变中心的 y 坐标,设置为矩形中心的 y 坐标
    intArrayOf(mStartColor, mMiddleColor, mEndColor), // 渐变颜色数组
    floatArrayOf(0f, 0.5f, 1f) // 颜色位置数组
)

SweepGradient没有映射方式

  • SweepGradient 没有 TileMode着色器映射方式,用于创建完整的圆周渐变,没有边缘、重复、镜像的颜色去绘制着色器区域之外的渐变,绘制起始点和结束点都是同一个,为创建SweepGradient对象传入
相关推荐
Near_Li1 小时前
uniapp-使用mumu模拟器调试安卓APP
android·uni-app
苹果醋31 小时前
React Native jpush-react-native极光推送 iOS生产环境接收不到推送
java·运维·spring boot·mysql·nginx
老华带你飞1 小时前
数码论坛|基于SprinBoot+vue的数码论坛系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·数码论坛系统
葵野寺1 小时前
【JVM】深入解析Java虚拟机
java·linux·jvm·gc·垃圾回收
程序猿七度2 小时前
【FastExcel】解决ReadSheet在Map中获取对象不准确问题(已提交PR并合并到开源社区)
java·开源·fastexcel
zhangphil2 小时前
Android MediaMetadataRetriever取视频封面,Kotlin(1)
android·kotlin
AI风老师3 小时前
5、docker镜像管理命令
java·docker·eureka
用户84913717547163 小时前
JustAuth实战系列(第5期):建造者模式进阶 - AuthRequestBuilder设计解析
java·设计模式·架构
励志成为糕手4 小时前
从反射到方法句柄:深入探索Java动态编程的终极解决方案
java·开发语言
是乐谷4 小时前
饿了么招java开发咯
java·开发语言·人工智能·程序人生·面试·职场和发展