SEO基础

SEO基础

Products

当前位置:首页 > SEO基础 >

如何实现自定义Drawable的圆角玻璃背景效果?

96SEO 2026-06-07 12:22 0


前言:聊聊为什么要自定义 Drawable 实现圆角玻璃背景

说实话,Android 原生的 shape、layer‑list 那套玩意儿Yi经够用了。

但是当你想要那种 iOS 那种毛玻璃模糊、边缘带点光晕的炫酷效果时普通 XML 就显得力不从心。

如何实现自定义Drawable的圆角玻璃背景效果?

哈哈,这时候自定义 Drawable 上场了。

它不仅Neng随时改颜色、圆角半径,还Neng直接当 background 给任何 View 用,简直是神器。

准备工作:先弄清楚 Drawable 的核心方法

自定义 Drawable 必须覆写几个关键函数:

draw —— 真正绘制的地方。

setAlpha、setColorFilter —— 控制透明度和颜色过滤。

getOpacity —— 告诉系统你的透明度类型。

onBoundsChange —— 当 View 大小变化时会回调,你Ke以在这里算出圆角半径和矩形区域。

别忘了还有两个可选的 getIntrinsicWidth/Height,用来支持 wrap_content 场景。

一步步实现「玻璃」效果的圆角 Drawable 1️⃣ 定义 Paint 并开启抗锯齿
private val paint = Paint.apply {
    style = Paint.Style.FILL
    // 这里先用半透明白色Zuo基底
    color = Color.argb
}
2️⃣ 用 BitmapShader Zuo模糊底纹

我们先把需要的背景图或者颜色画到一张 Bitmap 上,然后把它包装成 Shader,交给 Paint。

private fun createBlurShader: Shader {
    // 简单高斯模糊实现
    val bmp = Bitmap.createBitmap
    val canvas = Canvas
    canvas.drawColor // 清空
    // 绘制原始内容,这里就用纯色示例
    canvas.drawRect, height.toFloat,
        Paint.apply { color = Color.WHITE })
    // 用 BlurMaskFilter Zuo一次快速模糊
    val blurPaint = Paint.apply {
        isAntiAlias = true
        maskFilter = BlurMaskFilter
    }
    val blurredBmp = Bitmap.createBitmap
    val blurCanvas = Canvas
    blurCanvas.drawBitmap
    return BitmapShader(blurredBmp,
        Shader.TileMode.CLAMP,
        Shader.TileMode.CLAMP)
}
3️⃣ 在 draw 中绘制圆角矩形 + 边框光晕
override fun draw {
    // 绘制毛玻璃底层
    paint.shader = blurShader
    canvas.drawRoundRect
    // 再绘制一层半透明白色叠加,让整体geng柔和
    paint.shader = null
    paint.color = Color.argb
    canvas.drawRoundRect
    // Zui后加个细细的光晕边框
    if  {
        borderPaint.strokeWidth = strokeWidthPx
        borderPaint.color = borderColor
        canvas.drawRoundRect(rectFInset,
            cornerRadiusPx - strokeWidthPx / 2,
            cornerRadiusPx - strokeWidthPx / 2,
            borderPaint)
    }
}
4️⃣ 响应尺寸变化 & 圆角计算
override fun onBoundsChange {
    super.onBoundsChange
    rectF.set, bounds.top.toFloat,
              bounds.right.toFloat, bounds.bottom.toFloat)
    // 默认让圆角等于高度的一半,形成胶囊或圆形效果
    if  {
        cornerRadiusPx = bounds.height / 2f
    }
    // 边框内缩半个宽度,防止被裁切掉
    rectFInset.set(
        bounds.left + strokeWidthPx / 2,
        bounds.top + strokeWidthPx / 2,
        bounds.right - strokeWidthPx / 2,
        bounds.bottom - strokeWidthPx / 2)
   // geng新模糊 Shader,尺寸变了就重新生成
   blurShader = createBlurShader, bounds.height)
}
5️⃣ 暴露属性:圆角、边框宽度、是否亮色背景
var cornerRadius: Float
   get = cornerRadiusPx
   set { 
       cornerRadiusPx = value 
       customCorner = true 
       invalidateSelf
   }
var borderWidth: Float = 0f
   set {
       field = value
       strokeWidthPx = value * Resources.getSystem.displayMetrics.density
       invalidateSelf
   }
var lightBackground: Boolean = false
   set {
       field = value
       // 根据亮暗切换不同的边框颜色和透明度梯度
       borderColor = if  Color.parseColor
                    else Color.parseColor
       invalidateSelf
   }
把自定义 Drawable 丢进 XML:简洁又优雅

写完 Kotlin/Java 类之后只要在 res/drawable 下新建一个 XML 声明文件,就Neng像普通资源一样使用啦。



然后在布局里直接套:


进阶玩法:RuntimeShader 打造geng真实的液态玻璃

Ru果你的 App Zui低支持 Android 12以上,那Ke以直接玩 RuntimeShader,省去手动模糊的繁琐步骤。

private val runtimeShader by lazy {
   if  {
      RuntimeShader
   } else null
}
override fun draw {
   runtimeShader?.let { shader ->
      shader.setFloatUniform("iResolution",
         floatArrayOf.toFloat, bounds.height.toFloat))
      shader.setFloatUniform
      paint.shader = shader
      canvas.drawRoundRect(rectF,
         cornerRadiusPx,
         cornerRadiusPx,
         paint)
   } ?: run {
      // fallback to bitmap shader implementation...
   }
}

S H A D E R_CODE 大概长这样:


uniform float2 iResolution;
uniform half4 colorStart;
uniform half4 colorEnd;
uniform float cornerRadius;
half4 main{
   float2 uv = fragCoord / iResolution;
   float t =  * .5;
   half4 col = mix;
   // 简单圆角遮罩
   float dist=length-cornerRadius,float2));
   col.a *= smoothstep;
   return col;
}
为什么 RuntimeShader geng好?

- 完全在 GPU 上跑,帧率稳如老狗。

- 支持实时动画,比如随手指滑动改变光照方向。

- 不用担心内存泄漏,因为不再生成临时 Bitmap。

实战案例:给卡片视图加上「玻璃」边框

下面演示一下怎么把上面的 Drawable 用在 CardView 上,实现类似 iOS 卡片的磨砂外观:


     
         
         
     

然后在代码里给 ImageView 加上我们刚才写的「玻璃」背景:

val glassDrawable =
      ContextCompat.getDrawable as MyGlassDrawable
// 根据卡片暗色还是亮色动态切换属性,下面随便写个示例:
glassDrawable.lightBackground =
      resources.configuration.uiMode and Configuration.UI_MODE_NIGHT_MASK == Configuration.UI_MODE_NIGHT_NO
ivBg.background = glassDrawable
Trouble Shooting 小贴士

- 别忘了在 onBoundsChange 把 rectF 和 rectFInset dougeng新,否则会出现绘制偏移。

- Ru果发现边框颜色kan不见,请检查 alpha 值是否太低。

- 在低版本设备上一定要走 bitmap‑shader 分支,否则 RuntimeShader 会直接报错。

- 想让圆角随父容器自动适配,只需要不手动设置 customCorner 为 true,让它默认取高度的一半。

- 对于 RecyclerView 中大量使用这种 Drawable 的场景,Zui好缓存一下创建好的实例,否则每次 bind dou会重新生成 bitmap,引起卡顿。

感想:自定义 Drawable 真香!

说实话,我Zui开始也觉得自己写一个 drawable 太麻烦了直接去找第三方库吧。

结果自己撸出来以后才发现,这玩意儿真的是「一次写,多处用」的典范。

只要你掌握了上述几步,就Neng轻松搞定各种圆角、毛玻璃、渐变边框等炫酷需求——而且代码量根本不多,维护起来也hen舒服。

哈哈,Ru果你还有别的 UI 疑难杂症想聊聊,随时找我呀!咱就是说这篇文章Yi经帮你打开了一扇门,希望你们玩得开心~懂得的话点个赞呗~ 🤙🏻

关键词:Android 自定义 Drawable 圆角 胶囊 背景 毛玻璃 效果 RuntimeShader 实现教程 SEO 优化 教程 示例代码 源码解析 动态修改 背景颜色 UI 渲染 高性Neng 绘制 方法 实践案例 卡片视图 毛玻璃边框 Android 开发 技巧 分享 老友式讲解 随性口吻 情感化 文案 写作风格 非正式 带口头禅 哈哈 害 咱就是说 懂得你懂的 不对不对 应该是 …​
.


标签: 自定义

SEO优化服务概述

作为专业的SEO优化服务提供商,我们致力于通过科学、系统的搜索引擎优化策略,帮助企业在百度、Google等搜索引擎中获得更高的排名和流量。我们的服务涵盖网站结构优化、内容优化、技术SEO和链接建设等多个维度。

百度官方合作伙伴 白帽SEO技术 数据驱动优化 效果长期稳定

SEO优化核心服务

网站技术SEO

  • 网站结构优化 - 提升网站爬虫可访问性
  • 页面速度优化 - 缩短加载时间,提高用户体验
  • 移动端适配 - 确保移动设备友好性
  • HTTPS安全协议 - 提升网站安全性与信任度
  • 结构化数据标记 - 增强搜索结果显示效果

内容优化服务

  • 关键词研究与布局 - 精准定位目标关键词
  • 高质量内容创作 - 原创、专业、有价值的内容
  • Meta标签优化 - 提升点击率和相关性
  • 内容更新策略 - 保持网站内容新鲜度
  • 多媒体内容优化 - 图片、视频SEO优化

外链建设策略

  • 高质量外链获取 - 权威网站链接建设
  • 品牌提及监控 - 追踪品牌在线曝光
  • 行业目录提交 - 提升网站基础权威
  • 社交媒体整合 - 增强内容传播力
  • 链接质量分析 - 避免低质量链接风险

SEO服务方案对比

服务项目 基础套餐 标准套餐 高级定制
关键词优化数量 10-20个核心词 30-50个核心词+长尾词 80-150个全方位覆盖
内容优化 基础页面优化 全站内容优化+每月5篇原创 个性化内容策略+每月15篇原创
技术SEO 基本技术检查 全面技术优化+移动适配 深度技术重构+性能优化
外链建设 每月5-10条 每月20-30条高质量外链 每月50+条多渠道外链
数据报告 月度基础报告 双周详细报告+分析 每周深度报告+策略调整
效果保障 3-6个月见效 2-4个月见效 1-3个月快速见效

SEO优化实施流程

我们的SEO优化服务遵循科学严谨的流程,确保每一步都基于数据分析和行业最佳实践:

1

网站诊断分析

全面检测网站技术问题、内容质量、竞争对手情况,制定个性化优化方案。

2

关键词策略制定

基于用户搜索意图和商业目标,制定全面的关键词矩阵和布局策略。

3

技术优化实施

解决网站技术问题,优化网站结构,提升页面速度和移动端体验。

4

内容优化建设

创作高质量原创内容,优化现有页面,建立内容更新机制。

5

外链建设推广

获取高质量外部链接,建立品牌在线影响力,提升网站权威度。

6

数据监控调整

持续监控排名、流量和转化数据,根据效果调整优化策略。

SEO优化常见问题

SEO优化一般需要多长时间才能看到效果?
SEO是一个渐进的过程,通常需要3-6个月才能看到明显效果。具体时间取决于网站现状、竞争程度和优化强度。我们的标准套餐一般在2-4个月内开始显现效果,高级定制方案可能在1-3个月内就能看到初步成果。
你们使用白帽SEO技术还是黑帽技术?
我们始终坚持使用白帽SEO技术,遵循搜索引擎的官方指南。我们的优化策略注重长期效果和可持续性,绝不使用任何可能导致网站被惩罚的违规手段。作为百度官方合作伙伴,我们承诺提供安全、合规的SEO服务。
SEO优化后效果能持续多久?
通过我们的白帽SEO策略获得的排名和流量具有长期稳定性。一旦网站达到理想排名,只需适当的维护和更新,效果可以持续数年。我们提供优化后维护服务,确保您的网站长期保持竞争优势。
你们提供SEO优化效果保障吗?
我们提供基于数据的SEO效果承诺。根据服务套餐不同,我们承诺在约定时间内将核心关键词优化到指定排名位置,或实现约定的自然流量增长目标。所有承诺都会在服务合同中明确约定,并提供详细的KPI衡量标准。

SEO优化效果数据

基于我们服务的客户数据统计,平均优化效果如下:

+85%
自然搜索流量提升
+120%
关键词排名数量
+60%
网站转化率提升
3-6月
平均见效周期

行业案例 - 制造业

  • 优化前:日均自然流量120,核心词无排名
  • 优化6个月后:日均自然流量950,15个核心词首页排名
  • 效果提升:流量增长692%,询盘量增加320%

行业案例 - 电商

  • 优化前:月均自然订单50单,转化率1.2%
  • 优化4个月后:月均自然订单210单,转化率2.8%
  • 效果提升:订单增长320%,转化率提升133%

行业案例 - 教育

  • 优化前:月均咨询量35个,主要依赖付费广告
  • 优化5个月后:月均咨询量180个,自然流量占比65%
  • 效果提升:咨询量增长414%,营销成本降低57%

为什么选择我们的SEO服务

专业团队

  • 10年以上SEO经验专家带队
  • 百度、Google认证工程师
  • 内容创作、技术开发、数据分析多领域团队
  • 持续培训保持技术领先

数据驱动

  • 自主研发SEO分析工具
  • 实时排名监控系统
  • 竞争对手深度分析
  • 效果可视化报告

透明合作

  • 清晰的服务内容和价格
  • 定期进展汇报和沟通
  • 效果数据实时可查
  • 灵活的合同条款

我们的SEO服务理念

我们坚信,真正的SEO优化不仅仅是追求排名,而是通过提供优质内容、优化用户体验、建立网站权威,最终实现可持续的业务增长。我们的目标是与客户建立长期合作关系,共同成长。

提交需求或反馈

Demand feedback