在最近的一系列文章,对midipad APP,有一个关于一个radialgradiant渲染每个padview利用的探讨,对审美的原因,这是一个软件层,而不是一个硬件层。在这个简短的系列中,我们首先看看差异是什么,然后探索一种方法来调整硬件层。

在midipad的文章,我说我喜欢如何呈现的一个软件层的径向渐变,所以让我们开始比较同一径向出现时所采用的硬件和软件层。让我们先定义一个简单的自定义视图是viewpad中midipad文章大大简化版。它使用相同的技术–我们创建一个新的径向尺寸变化时的观点,但径向本身是在PadView使用的使用非常相似。shaderfactory的使用是一种机制,我们将使用后在不同的径向厂替代。

class GradientView @JvmOverloads constructor(

context: Context,

attrs: AttributeSet? = null,

defStyleAttr: Int = 0,

defStyleRes: Int = 0,

private val bounds: RectF = RectF()

) : View(context, attrs, defStyleAttr, defStyleRes) {

private val defaultColour: Int by lazyFast {

context.theme.getColour(R.attr.colorAccent)

}

private val paint: Paint =

Paint().apply {

isAntiAlias = true

style = Paint.Style.FILL

}

var shaderFactory: (width: Float, height: Float) -> Shader = { viewWidth, viewHeight ->

RadialGradient(

viewWidth / 2f,

viewHeight / 2f,

Math.min(viewWidth, viewHeight) / 2f,

defaultColour,

Color.TRANSPARENT,

Shader.TileMode.CLAMP

)

}

override fun onSizeChanged(newWidth: Int, newHeight: Int, oldWidth: Int, oldHeight: Int) =

super.onSizeChanged(newWidth, newHeight, oldWidth, oldHeight).run {

adjustBounds(newWidth.toFloat(), newHeight.toFloat())

}

private fun adjustBounds(width: Float, height: Float) {

bounds.set(0f, 0f, width, height)

paint.shader = shaderFactory(width, height)

}

override fun onDraw(canvas: Canvas?) {

super.onDraw(canvas)

canvas?.drawRect(bounds, paint)

}

}

我们现在可以创建一个布局,其中包含4个视图,其中两个在一个黑暗的背景下,两个在一个光的背景下。相同背景的每一对都由一个使用硬件层渲染,一个使用软件层渲染:

xmlns:app="http://schemas.android.com/apk/res-auto"

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context="com.stylingandroid.radialgradient.MainActivity">

android:layout_width="0dp"

android:layout_height="0dp"

android:background="@android:color/black"

app:layout_constraintBottom_toBottomOf="@+id/dark_hardware"

app:layout_constraintEnd_toEndOf="parent"

app:layout_constraintStart_toStartOf="parent"

app:layout_constraintTop_toTopOf="parent" />

android:id="@+id/dark_hardware"

android:layout_width="0dp"

android:layout_height="0dp"

android:layout_margin="8dp"

android:layerType="hardware"

app:layout_constraintBottom_toTopOf="@+id/light_hardware"

app:layout_constraintEnd_toStartOf="@+id/dark_software"

app:layout_constraintStart_toStartOf="parent"

app:layout_constraintTop_toTopOf="parent" />

android:id="@+id/dark_software"

android:layout_width="0dp"

android:layout_height="0dp"

android:layout_margin="8dp"

android:layerType="software"

app:layout_constraintBottom_toTopOf="@+id/light_software"

app:layout_constraintEnd_toEndOf="parent"

app:layout_constraintStart_toEndOf="@+id/dark_hardware"

app:layout_constraintTop_toTopOf="parent" />

android:id="@+id/light_hardware"

android:layout_width="0dp"

android:layout_height="0dp"

android:layout_margin="8dp"

android:layerType="hardware"

app:layout_constraintBottom_toBottomOf="parent"

app:layout_constraintEnd_toStartOf="@+id/light_software"

app:layout_constraintStart_toStartOf="parent"

app:layout_constraintTop_toBottomOf="@+id/dark_hardware" />

android:id="@+id/light_software"

android:layout_width="0dp"

android:layout_height="0dp"

android:layout_margin="8dp"

android:layerType="software"

app:layout_constraintBottom_toBottomOf="parent"

app:layout_constraintEnd_toEndOf="parent"

app:layout_constraintStart_toEndOf="@+id/light_hardware"

app:layout_constraintTop_toBottomOf="@+id/dark_software" />

如果我们现在在黑暗背景下比较这两个,我们可以看到它们的出现有很大的不同:

使用软件层呈现的是右边,而这一个看起来更适合我想要达到的目标。它褪得稍微快一点,看起来更漂亮。但是,如果我选择使用一个光的背景,我肯定我会选择使用硬件层渲染的那个:

再一次,使用软件层呈现的是右边的一个,现在有一个暗晕,看起来不太好。

为了理解为什么会出现这种差异,让我们先退一步,了解一下硬件和软件层实际上做了什么。

android activity 渐变,关于Android的径向渐变高级编程的实现相关推荐

  1. html css径向渐变,如何实现css3径向渐变如何定义中心和大小形状

    如何实现css3径向渐变如何定义中心和大小形状 发布时间:2020-07-13 16:23:57 来源:亿速云 阅读:249 作者:Leah 如何实现css3径向渐变如何定义中心和大小形状?很多新手对 ...

  2. android activity透明主题,Android应用的全透明效果--Activity及Dialog的全透明

    1.Activity全透明 同学给了这个有趣的代码,现在公布出来. 先在res/values下建colors.xml文件,写入:<?xmlversion ="1.0"enco ...

  3. android activity 淡入 动画,android – 如何在Activity转换上执行淡入淡出...

    您可以创建自己的.xml动画文件以淡入新活动并淡出当前活动: fade_in.xml android:interpolator="@android:anim/accelerate_inter ...

  4. android activity 回调函数,Android Activity的生命周期

    Activity的生命周期 Android系统根据activity的所处不同阶段对应的唤起其特定的回调函数来执行代码.activity的一系列有序的生命周期回调函数.本文将来讨论下activity各阶 ...

  5. android activity滑动切换,Android 向右滑动切换Activity, 随着手势的滑动而滑动的效果...

    [实例简介] Android 向右滑动切换Activity, 随着手势的滑动而滑动的效果,项目详情http://blog.csdn.net/xiaanming/article/details/2093 ...

  6. android activity pause,关于android:onPause()和onStop()在Activity中

    我是Android开发的新手,但我仍然无法理解活动中的onPause()和onStop()方法. 在我的应用程序中,我有一个名为Counter的静态类,该类将变量的状态保存在应用程序的内存中.我的应用 ...

  7. android activity 通知 service,android activity和service通信问题

    首先,题主有个理解错误的地方, startService 只是开启 service ,service运行在后台,还是有可能因内存不足而被杀死. 第二点, service 可以以混合启动的形式启动,也就 ...

  8. CSS3 渐变: 线性渐变 linear-gradient 和 径向渐变 radial-gradient

    渐变背景也是CSS3 的新特性,通过它可以在不使用图像的情况下,创建从一种颜色到另一种颜色的过渡.使用渐变的好处是,可以减少对图像的依赖,进而降低浏览网页时的带宽消耗,提高网站的访问速度. 渐变,就是 ...

  9. CSS线性渐变和径向渐变详解

    第九章:渐变色 1.线性渐变 1.1.什么是线性渐变 1.2线性渐变的写法 2.径向渐变 2.1什么是径向渐变 2.2径向渐变的写法 总结 1.线性渐变 1.1.什么是线性渐变 线性渐变,顾名思义就是 ...

  10. html设置径向渐变色,【前端Talkking】CSS系列-css3之径向渐变初探

    1 径向渐变radial-gradient 这是关于渐变的第二篇文章径向渐变,第一篇文章是线性渐变,有兴趣的可以看这里 1.1 基本语法 线性渐变是沿着一条直线渐变,而径向渐变则是沿着椭圆或者圆进行渐 ...

最新文章

  1. elasticsearch学习之路---Linux 下安装并启动elasticsearch
  2. boost::unknown_exception用法的测试程序
  3. hdu 4419 Colourful Rectangle (离散化扫描线线段树)
  4. zoj2968 Difference Game
  5. mysql如何备份一个表单_Mysql亿级数据大表单表备份
  6. IntentService的使用介绍
  7. python视频教程-中谷python中文视频教程(全38集)
  8. MySQL命令行导入导出sql文件
  9. mysql alter table 速度慢_mysql问题: alter导致速度慢 | 学步园
  10. 函数论_E.C.Tichmarsh_Page 4 级数一致收敛的魏尔斯特拉斯 M-判别法 的推广
  11. 电脑重装:微PE工具箱重装win10系统
  12. 摄魄人心的独白,静静聆听,你会感悟很多
  13. 如何建立网站登录系统?
  14. 基于mahout的动漫推荐系统
  15. 《卸甲笔记》-单行函数对比之三
  16. 【原创】kettle转换组件杂记-【javascript组件】获取当前时间的前一天/后一天
  17. Excel 2007 制作双Y轴图形
  18. NewbieGuide setBackgroundColor为transparent无效
  19. linux进程创建 摘要,文章摘要 lnmp的搭建
  20. 公司对不实舆情该如何进行处置和公关?

热门文章

  1. 从零单排之玩转Python安全编程(II)
  2. JS之数据_变量_内存v(**V**)v(2)
  3. 1.3 xss原理分析与剖析(4)
  4. 深入了解UIAutomation 的API
  5. WEB前端技术趋势图示-JS库
  6. 风云点评:Flash 与 Silverlight 终极大比拼
  7. java ML回归预测_ML之回归预测:利用九大类机器学习算法对无人驾驶汽车系统参数(2018年的data,18+2)进行回归预测值VS真实值...
  8. js 设备条形码字体_蚌埠食品袋激光打码机设备-青岛博泰格睿特
  9. iOS之深入解析CFRunloop的多线程隐患
  10. Selenium Xpath元素无法定位 NoSuchElementException: Message: no such element: Unable to locate element