Android群英传读书笔记(第十二章)

第十一章介绍的是云端服务器搭建方面的知识,暂且略过,本章主要介绍的是Android5.X新特性。
本章介绍了许多Material Design的概念,在此不做记录。
另外本章记录了许多新特性里包括了许多动画特效,大家可以自行谷歌百度查看效果。

1.Palette

Palette用来提取颜色,使用它能从Bitmap中提取色调,从而修改当前主题的颜色。
Android内置了几种提取色调的种类如下:

  • Vibrant(充满活力的)
  • Vibrant dark(充满活力的暗)
  • Vibrant light(充满活力的亮)
  • Muted(柔和的)
  • Muted dark(柔和的暗)
  • Muted light(柔和的亮)

使用Palette需要先在Android studio中添加相关的依赖:com.android.support:palette-v7:xx.x.x引用。可以通过传递一个Bitmap对象给Palette,书中写是用它的Palette.generate()静态方法或者Palette.generateAsync()方法来创建一个Palette。然而这两个方法已经过时了,改用建造者模式来创建对象了。

代码:

 Palette.from(bitmap).generate(new Palette.PaletteAsyncListener() {
            @Override
            public void onGenerated(Palette palette) {
                //通过Palette来获取对应的色调
                Palette.Swatch vibrant=palette.getDarkVibrantSwatch();
                //将颜色设置给相应的组件
                btn.setBackgroundColor(vibrant.getRgb());
            }
        });

2.视图与阴影

Android的View通常具有X和Y两个属性,在5.X中谷歌新增了一个Z属性来控制对应垂直方向上的高度变化。它由elevationtranslationZ两部分组成,elevation是静态的成员,translationZ可以在代码中使用来实现动画效果。Z=elevation+translationZ

  • 在XML中使用elevation来定义Z的高度:android:elevation="XXdp"
  • 在代码中通过translationZview.setTranslationZ(XXX)或者使用动画view.animate().translationZ(100)

3.Tinting和Clipping

  • Tinting(着色):
    在XML中配置好tine和tintMode就可以实现对图片的着色,它通过修改图形的Alpha遮罩来修改图像的颜色,从而达到重新着色的目的
<ImageView 
      android:layout_width="100dp"
      android:layout_height="100dp"
      android:src="@drawable/icon"
      android:tint="@color/blue"
/>
  • Clipping(裁剪):
    Clipping可以让我们改变一个视图的外形,首先我们需要使用ViewOutlineProvider修改outline然后再通过设置setOutlineProvider将outline作用给视图。
    代码:
//宽高100的textview
ViewOutlineProvider vop=new ViewOutlineProvider(){
      @Override
      public void getOutline(View view,Outline outline){
               //修改outline为特定形状
               outline.setRoundRect(0,0,textView.getWidth(),textView.getHeight(),30);
      }
};
textView.setOutlineProvider(vop);
//设置完以后将会看到一个圆角的矩形

4.列表和卡片

  • RecyclerView:
    个人感觉是一个升级版的ListView,在其Adapter内已经封装好一个ViewHolder,并且可以通过不同的LayoutManager来直接实现类似GridView或者是瀑布流的样式。但是RecyclerView并没有header、footer以及点击事件,这些如果有需求则需要自己来实现。RecyclerView介绍以及RecyclerView添加header、footer方案感觉比书中的介绍的要详细,在此就不多做记录!

  • CardView:
    CardView也是一种容器布局,只是它提供了卡片这样的一种形式,开发者可以定义卡片大小与视角高度,并设置圆角的角度,如果要作为列表来使用最好配合RecyclerView而不是ListView,否则一些属性会失效。
    CardView通过cardBackgroundColor来设置背景色,通过cardCornerRadius来设置圆角角度,这两个是自定义的属性需添加res-auto才能使用。

5.Activity过渡动画

Android5.X提供了三种Transition类型。

  • 进入:一个进入的过渡动画决定Activity中的所有的视图怎么进入屏幕。
  • 退出:一个退出的过渡动画决定了一个Activity中的所有视图怎么退出屏幕。
  • 共享元素:一个共享元素过渡动画决定了两个Activities之间的过渡,怎么共享它们的视图。

其中进入和退出包括:

  • explode(分解):从屏幕中间进或者出,移动视图。
  • slide(滑动):从屏幕边缘进或者出,移动视图。
  • fade(淡出):通过改变屏幕上视图的不透明度达到添加或者移除视图。

共享元素包括:

  • changeBounds:改变目标视图的布局边界
  • changeClipBounds:裁剪目标视图边界
  • changeTransform:改变目标视图的缩放比例和旋转角度
  • changeImageTransform:改变目标图片的大小和缩放比例

进入和退出的代码:

//ActivityA中:
startActivity(intent,ActivityOptions.makeSceneTransitionAnimation(this).toBundle());
//ActivityB中:
getWindow().requestFeature(Window.FEATURE_CONTENT_TRANSITIONS);
//进入B的动画
getWindow().setEnterTransition(new Explode());
//退出B的动画
getWindow().setExitTransition(new Explode());

其实这和以前的overridePendingtransition()差不多,并且这个方法并不兼容5.0以下。

共享元素代码:
首先需要在ActivityA中的布局文件中设置共享元素,给它增加相应的属性:

android:transitionName="XXX"

同时在Activity2中药实现共享效果的元素也增加相同的属性,代码同上,并且保证命名相同。
如果只要一个共享元素,那么Activity1中只需要使用如下代码:

//使用的代码就是在前面普通动画的基础上增加了共享的View和前面取的名字。
startActivity(intent,ActivityOptions.makeSceneTransitionAnimation(this,view,"share").toBundle());

如果有多个元素需要共享,那么可以通过Pair.create()来创建多个共享元素:

startActivity(intent,ActivityOptions.makeSceneTransitionAnimation(this,Pair.create(view,"share"),Pair.create(fab,"fab")).toBundle());

6.Ripple效果

Ripple即点击后的波纹效果。可以通过如下代码进行设置:

//波纹有边界
android:background="?android:attr/selectableItemBackground"
//波纹超出边界
android:background="?android:attr/selectableItemBackgroundBorderless"

7.Circular Reveal

这个动画效果在谷歌IO大会的演示视频中出现了很多次,具体表现为一个View以圆形的形式展开、揭示出来。通过ViewAnimationUtils.createCircularReveal()方法可以创建一个Reveal动画,其中需传入几个参数:

  • centerX 动画开始的中心点X
  • centerY 动画开始的中心点Y
  • startRadius 动画开始半径
  • endRadius 动画结束半径

8.Toolbar

Toolbar与Actionbar最大的区别就是它更加自由可控。要使用Toolbar必须引入支持appcompat-v7,并设置主题为NoActionBar。其菜单的配置与Actionbar基本类似,通过setSupportActionBar(toolbar)方法可以用Toolbar模拟出Actionbar的效果。

9.Notification

在Android5.X上谷歌改进了通知栏,优化了Notification,长按Notification时会显示出消息来源。Notification会有一个从白色到灰色的动画切换效果,最终显示发出这个Notification的调用者,同时在锁屏状态下我们也可以看见Notification通知了。

  • 基本的Notification
    通过Notification.Builder创建一个Notification的builder:
Notification.Builder builder=new Notification.Builder(this);

接下来需要提供一个延迟的Intent即PendingIntent:

//点击Notification之后就会触发PendingIntent事件,打开浏览器开始浏览网页。
Intent intent=new Intent(Intent.ACTION_VIEW,Uri.parse("http://www.sina.com"));
PendingIntent pendingIntent=PendingIntent.getActivity(this,0,intent,0);

Notification还可以添加各种属性:

builder.setSmallIcon(R.drawable.ic_launcher);
builder.setContentIntent(pendingIntent);
builder.setAutoCancel(true);
builder.setContentTitle("test");
.....

Android系统通过NotificationManager系统服务来帮助我们管理Notification:

//调用notify方法时需传入一个ID,用来区分不同的App的Notificaiton。
NotificationManager nM=(NotificationManager) getSystemService(NOTIFICATION_SERVICE);
nM.notify(NOTIFICATION_ID_BASIC),builder.build());
  • 折叠式Notification
    折叠式Notification也是一种自定义视图的Notification,常用于显示长文本。它拥有两个视图,一个是普通状态下的视图状态,另一个是展开状态下的视图状态。需要RemoteViews来帮助创建一个自定义Notification。
//正常状态视图
notification.contentView=contentView;
//展开状态视图
notificaiton.bigContentView=expandedView;
  • 悬挂式Notification
    悬挂式Notification是Android5.0新增加的方式,可以在屏幕上方产生Notification切不会打断用户从操作,主要通过setFullScreenIntent,可以很轻松地将一个Notification变成一个悬挂式Notification。

  • 显示等级的Notification
    分为3个等级:

    • VISIBILITY_PRIVATE:表明只有当没有锁屏的时候会显示。
    • VISIBILITY_PUBLIC:表明在任何情况下都会显示。
    • VISIBILITY_SECRET:表明在pin、password等安全锁和没有锁屏的情况下才能够显示。

代码中具体通过builder的setVisibility()

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

推荐阅读更多精彩内容