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

为什么要使用 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、性能优化、数据结构和算法、移动架构四个模块。在整理的过程中,我会做下笔记并整理分享出来。准备用六个月左右的时间完成这件事,如果中途停更了,欢迎打脸。

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,711评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,932评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,770评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,799评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,697评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,069评论 1 276
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,535评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,200评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,353评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,290评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,331评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,020评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,610评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,694评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,927评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,330评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,904评论 2 341

推荐阅读更多精彩内容