关于知乎新闻案例的模仿

1.ToolBar

参看该文章http://www.jianshu.com/p/79604c3ddcae
项目参看: SystemUITest

2.RecyclerView

http://www.jianshu.com/p/f592f3715ae2

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:layout_width="match_parent"
              android:layout_height="match_parent"
              android:orientation="vertical">

    <com.example.systemuitest.AttrsTypedArray.CustomView
       //放在这个地方没有问题
        xmlns:xyz="http://schemas.android.com/apk/res/com.example.systemuitest"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        xyz:text="hello"
        xyz:textAttr="29"
        />

</LinearLayout>

关于命名空间参考:http://blog.csdn.net/janice0529/article/details/34425549

TypedArray是(存放attrs列出的属性值)方便直接取出

public class CustomView extends View {
    private static final String TAG=CustomView.class.getSimpleName();
    public CustomView(Context context, AttributeSet attrs) {
        super(context, attrs);
        //Return a TypedArray holding the attribute values in set that are listed in attrs.
        //返回一个TypedArray(存放attrs列出的属性值)
        TypedArray ta = context.obtainStyledAttributes(attrs, R.styleable.test);
        String text = ta.getString(R.styleable.test_text);//别忘了是放在styleable之下的
        int textAttr = ta.getInteger(R.styleable.test_textAttr, -1);
        Log.e(TAG, text+"----"+textAttr );

        ta.recycle();
    }
}

关于第一篇博文中用数组存储attr的属性值,并用TypedArray通过下标获取对应的属性值
会出现一个bug:

Error: Expected resource of type styleable

解决方法如下:在使用 TypedArray 的方法处
加上 @SuppressWarnings("ResourceType")

 @SuppressWarnings("ResourceType")

案例代码

//在这儿加的
@SuppressWarnings("ResourceType")
public class CustomVewActivity extends View {
    private static final String TAG = CustomVewActivity.class.getSimpleName();
    private static final int[] mAttrs = {R.attr.test3, R.attr.test4};

    public CustomVewActivity(Context context, AttributeSet attrs) {
        super(context, attrs);

        TypedArray ta = context.obtainStyledAttributes(attrs, mAttrs);
        String test3 = ta.getString(0);
        int test4 = ta.getInteger(1, -1);

        Log.e(TAG, test3+"--"+test4 );
        ta.recycle();
    }
}


getItemOffsets():从字面意思就是Item要偏移, 由于我们在Item和Item之间加入了分隔线,线其实本质就是一个长方形,也是用户自定义的,既然线也有长宽高,就画横线来说,上面的Item加入了分隔线,那下面的Item就要往下平移,平移的量就是分隔线的高度。

  • 关于分割线后续实际代码

上面两篇已经讲得很清楚了,原理就是第一篇博文写的那样,很清晰明白,需要注意的问题是在列表方向是垂直的时候(一般为默认),需要画水平线,第一篇博文思路很清晰,问题在于列表方向是垂直的时候,item应该向下平移

3. DrawingCache

缓存视图.png

关于这段代码其中用到DrawingCache,官网API解释:

void setDrawingCacheEnabled (boolean enabled)

Enables or disables the drawing cache. When the drawing cache is enabled, the next call to getDrawingCache() or buildDrawingCache() will draw the view in a bitmap. Calling [draw(android.graphics.Canvas)]
will not draw from the cache when the cache is enabled. To benefit from the cache, you must request the drawing cache by calling getDrawingCache()
and draw it on screen if the returned bitmap is not null.

关于参数:
boolean enabled: true to enable the drawing cache, false otherwise

http://1137907860.blog.51cto.com/10452906/1682078中说到

若想更新cache, 必须要调用destoryDrawingCache方法把旧的cache销毁,才能建立新的。
>当调用setDrawingCacheEnabled方法设置为false, 系统也会自动把原来的cache销毁。

对比看
http://souly.cn/%E6%8A%80%E6%9C%AF%E5%8D%9A%E6%96%87/2016/01/05/DrawingCache%E8%A7%A3%E6%9E%90/

有点不同暂时先记录吧

4.ObjectAnimation

关于这部分之前已经接触过而且比较简单,只是实现一下动画的类型直接参看下面一篇文章即可
http://blog.csdn.net/dingfengnupt88/article/details/51556597

透明度(alpha)

透明度.png

代码实现如上:该示例代码并没有在onAnimationEnd中实现相应函数

5.ViewStub

参看
http://souly.cn/%E6%8A%80%E6%9C%AF%E5%8D%9A%E6%96%87/2015/09/18/ViewStub%E7%94%A8%E6%B3%95%E5%88%86%E6%9E%90/

1.用途:
最大的用途就是实现View的延迟加载,在需要使用的时候再加载view
在这个项目中作者是用来显示网络通知的(平时不需要显示,在无网络时使view可见)
2.特点
ViewStub inflate之后就会变成空的(所以点击第一次按钮textView会显示出来,第二次点击会报空指针异常 最好加一个非空判断

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

推荐阅读更多精彩内容

  • 曾记得远在他乡 思绪飘渺 小时候的记忆 如诗般美好 当秋风起 枫叶落 一地思念 这一时的景 如痴如醉 如梦似幻 恍...
    sujing123阅读 160评论 4 5
  • 当下网络发达的时代,成就了一批批的商业精英,以马云为首在中国商业精英开辟的网上购物热潮,彻底打破了人们以前的生活和...
    喜水阅读 707评论 1 3
  • 首先的首先,官网介绍使用和注意事项的地址,说实话,太长了我自己就看了一点点。 那就说我是如何瞎用的。首先,由于知识...
    美男子_杰琳塔阅读 646评论 0 1
  • 完全走出别人眼光的枷锁,是需要发展出两种基本能力: 欣赏能力,能够欣赏自己和欣赏他人的长项; 拒绝能力,能够否认别...
    心理咨询师Lily阅读 686评论 0 1