Android composse 声明式UI,更简单的自定义

Android compose

声明式UI,更简单的自定义; 实时带交互的预览功能 Compose 并不是类似于Recyclerview的高级控件,而是直接抛弃了View,ViewGroup那套东西,从上到下鲁了一套全新的框架,直白点说就是它的渲染机制,布局机制,触摸算法,以及UI 具体写法全都是新的

Compose 实现了声明式UI,替代传统的命令是UI; 可能对于我们来说第一个问题就是什么是声明式?什么是命令式UI? 首先看一下声明式UI长什么样

Compose是用kotlin来写的,它的每一个控件都是一个函数调用; Text() Text()并不会创建对象,它不是一个构造函数,而是一个普通函数;为了辨识度,Compose函数开头都是大写;也就是一个Composable

有人会疑问Text()地层到底是什么,是个Textview吗? 其实并不是它是更下层Canvas那套东西, Compose各个组件都是独立的新实现

看完它的写法,看刚才的问题什么是声明式UI,它这么写怎么就声明式了,它和我们一直以来的写法有什么区别

<pre mdtype="fences" cid="n107" lang="" class="md-fences md-end-block ty-contain-cm modeLoaded" spellcheck="false" style="box-sizing: border-box; overflow: visible; font-family: var(--monospace); font-size: 0.9em; display: block; break-inside: avoid; text-align: left; white-space: normal; background-image: inherit; background-position: inherit; background-size: inherit; background-repeat: inherit; background-attachment: inherit; background-origin: inherit; background-clip: inherit; background-color: rgb(248, 248, 248); position: relative !important; border: 1px solid rgb(231, 234, 237); border-radius: 3px; padding: 8px 4px 6px; margin-bottom: 15px; margin-top: 15px; width: inherit; color: rgb(51, 51, 51); font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: normal; orphans: 2; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration-style: initial; text-decoration-color: initial;">
 <LinearLayout
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:orientation="vertical"
 >
 <TextView
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:text="hello"
 />
 <TextView
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:text="world"
 />
 </LinearLayout></pre>

这是传统写法,还需要在java中 findviewbyId获取控件对象,来进行操作; 其实对于布局来说,写法大同小异,但是为什么传统写法叫命令式,而Compose叫声明式

对于声明式来说,你只需要把控件声明出来,而不需要手动更新; 如左边对应的Textview 它对应的数据改变了,我们怎么去更改数据呢,首先是findviewbyId获取控件对象,然后setText来进行数据变更; 而如果用Compose呢,则不用更新,当数据改变时Compose会自动更新到页面上

这个自动订阅功能很容易使用,你只要在初始化时加上by mutableStateOf,剩下全由Compose自动搞定; 这个神奇的特性,是利用了kotlin的Property Delegation来实现的,也就说明了为什么Compose只能用kotlin来编写,因为使用到了kotlin的许多特性,而这些特性使用java 不能简单实现

这就是所谓的声明式UI,你只要声明页面是什么样子,不用手动去更新; 因为页面会自动更新,传统页面如果数据发生改变,要使用代码,给出详细步骤命令代码去更新,这就是所谓的命令式

传统的所谓命令式,并不在XML部分,而是在于java部分; java代码去指挥去命令控件去更新,这才是命令式含义所在,而Compose通过订阅机制来更新UI,不需要指挥控件去更新,所以是声明式; 它并不是语言角度的定义,也不是写法角度定义,而是功能角度

换句话说如果传统的XML能通过数据和页面进行关联,让页面自动更新,而不是让咱们去指定更新,那

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android 系统界面的一部分是 SystemUI。它是 Android 操作系统的一个系统应用程序,提供了通知栏、状态栏、快捷设置等重要的用户界面元素。如果您想要自定义 SystemUI,可以按照以下步骤进行操作: 1. 首先,您需要了解 SystemUI 的架构和工作原理。它是一个基于 Java 的应用程序,使用 Android 的 Binder 机制与系统服务通信。您可以通过下载 Android 源代码并查看源代码来深入了解其工作原理。 2. 然后,您需要创建一个新的 Android 应用程序项目,并将其配置为 SystemUI 扩展。这可以通过在 manifest 文件中声明一个文件提供者来实现。例如: ```xml <provider android:name=".SystemUIProvider" android:authorities="com.example.systemui.provider" android:exported="true" android:grantUriPermissions="true"> <meta-data android:name="com.android.systemui" android:resource="@xml/systemui_extensions" /> </provider> ``` 其中,`SystemUIProvider` 是您创建的文件提供者类的名称,`com.example.systemui.provider` 是您自己的包名,`@xml/systemui_extensions` 是您的扩展配置文件的资源 ID。 3. 接下来,您需要创建一个扩展配置文件,以指定 SystemUI 如何加载您的扩展。例如: ```xml <extensions> <extension class="com.example.systemui.MyExtension" targetPackage="com.android.systemui" targetClass="com.android.systemui.statusbar.phone.PhoneStatusBar" attach="true" /> </extensions> ``` 其中,`MyExtension` 是您创建的扩展类的名称,`com.android.systemui.statusbar.phone.PhoneStatusBar` 是您要扩展的目标类的完全限定名称。 4. 最后,您需要创建一个扩展类,并实现所需的功能。例如,如果您想要添加一个新的按钮到状态栏,您可以创建一个 `View`,并将其添加到状态栏中。您可以使用 Android 提供的 `StatusBarManager` 类来添加视图。 以上是自定义 Android SystemUI 的大致步骤,希望对您有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值