MaterialDesign--(1)Google精心准备的Ap

作者: Anonymous___ | 来源:发表于2017-07-17 15:32 被阅读0次

    为什么要使用 appcompat,因为里面是 google 精心准备得--解决 android 碎片化开发蛋疼的问题,让我们的 app 编译出来在各种高低版本之间、不同的厂商生产的 ROM 之间显示出来的效果 UI 控件等有比较一致的体验。

    怎么用?

    1、引入 appcompat-v7项目,在 gradle文件里面添加 compile 'com.android.support:appcompat-v7:25.3.1'的依赖(25.3.1只是其中一个版本),studio 会在创建项目的时候自动添加这个。如果在引用的时候报错,则一般是由于 SDK、Appcompat-v7、build 版本新旧不兼容引起的,调整为合适的版本重新 build 即可。
    2、打开 res/value/styles.xml文件定义如下主题:

     <!--actionBar栏颜色 不能添加透明通道-->
        <item name="colorPrimary">@color/colorPrimary</item>
        <!--状态栏颜色-->
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <!--editText线条、radioButton按钮颜色-->
        <item name="colorAccent">@color/colorAccent</item>
        <item name="android:windowTranslucentStatus">true</item>
        <!--actionBar文字颜色-->
        <item name="android:textColorPrimary">#afaf00</item>
        <!--主背景颜色-->
        <item name="android:windowBackground">@color/windowBackground</item>
        <!--虚拟按钮颜色需要api21-->
        <item name="android:navigationBarColor">@color/navigationBarColor</item>
    

    可能上面每条属性的文字描述不够明确,一张图看懂:

    3、Activity 继承 AppcompatActivity

    MaterialDesign 兼容性控件及主题

    • 在 Appcompat-v7包里面有很多为兼容而生的控件
    • 使用这些控件可以做到高低版本和不同的 ROM 之间体验一致。还可以配合 Appcompat 的主题使用达到体验一致性

    1、兼容控件

    先感受一下API16和 API23的 dialog,撇开颜值不说,你们产品能接受 app 在不同的系统之间对话框这么大的差异么

    dialog.png

    所以在开发当中,dialog 一般用的是 v7包下的兼容类android.support.v7.app.AlertDialog,点进源码里面,我们可以看到 AlertDialog 继承的是AppCompatDialog。

    其实 Appcompat-v7包给我们准备了很多很多兼容控件,具体有哪些,同学们可以点开源码自行阅读。

    Appcompat 兼容控件.png

    2、Appcompat 兼容主题
    Appcompat 包的 res 里面有很多定义好的主题,有兴趣的同学也可以好好研究一下,常用的控件都有。

    Appcompat 兼容 style.png

    有话说

    做了几年的 Android 开发,平时也都有学习充电,掘金简书的技术文章更是从最终的每篇必读、每个代码都会下载下来看一看到现在的看到标题,就大致知道作者想要写什么东西,大致是怎样实现的,然后点进去看一下,如果和自己猜想一样,就直接略过了。听起来好像成长了,但是实际开发中,遇到同样的问题,还是得去翻别人的博客 copy 代码,虽然并不是盲目的copy,但是终究不是自己纯手撸出来的。

    做了几年开发,一路上走过来也和不少程序员打过交道,他们当中大部分都是 Coder,但也有不少 Developer。而我,也只是一个自命不凡的 Coder。

    做为一个自命不凡的 Coder,还是要有点梦想的。这次的梦想就是准备把这两年学习的零零碎碎知识点重新梳理一遍,整理出自己的知识体系,巩固基础。记得有个前辈一直是这样教导我的:这些都是基础,你不会?知识一点要成体系,成了体系才能进阶;要有自己的思想,别仅仅停留在代码实现需求。

    说了很多废话,说说重点。本次规划的知识体系有:高级 UI、性能优化、数据结构和算法、移动架构四个模块。在整理的过程中,我会做下笔记并整理分享出来。准备用六个月左右的时间完成这件事,如果中途停更了,欢迎打脸。

    最后,有些东西可能被我一笔带过了,如果给读者同学造成困惑,可以在下面留言提问,我看到会第一时间回复的。

    相关文章

      网友评论

        本文标题:MaterialDesign--(1)Google精心准备的Ap

        本文链接:https://www.haomeiwen.com/subject/byzfkxtx.html