SearchView的使用

搜索功能是Android常見的功能之一凉蜂,在v7包就有一個(gè)控件SearchView,用來實(shí)現(xiàn)搜索功能,而在普通widget包中也有一個(gè)SearchView尼摹,兩者用處一樣,只不過在使用方式上有一點(diǎn)區(qū)別剂娄,同時(shí)widget包中的SearchView只能在3.0(API 11)版本以上使用蠢涝,而v7包中的SearchView能兼容到2.1(API 7).
今天介紹的就是v7包中的SearchView.

官方文檔

使用前添加依賴:

compile 'com.android.support:appcompat-v7:25.3.1'

一、單獨(dú)使用

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

    <android.support.v7.widget.SearchView
        android:id="@+id/searview"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:iconifiedByDefault="false"
        app:queryHint="請(qǐng)輸入搜索內(nèi)容" />

    <ListView
        android:id="@+id/listview"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1" />

</LinearLayout>
public class MainActivity extends AppCompatActivity {

    private SearchView mSearchView;
    private ListView mListView;
    private ArrayAdapter mAdapter;
    private String [] data = {"Java","kotlin","C","C++","C#","Python","PHP","JavaScript"};

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mListView = (ListView) findViewById(R.id.listview);
        mAdapter = new ArrayAdapter(MainActivity.this, android.R.layout.simple_list_item_1, data);
        mListView.setAdapter(mAdapter);
        mListView.setTextFilterEnabled(true);

        mSearchView = (SearchView) findViewById(R.id.searview);
        mSearchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
            @Override
            public boolean onQueryTextSubmit(String query) {
                return false;
            }
            @Override
            public boolean onQueryTextChange(String newText) {
                mAdapter.getFilter().filter(newText);
                return false;
            }
        });
    }
}

這里為了書寫簡便就沒有搭配RecyclerView了阅懦,而是搭配ListView使用和二,為SearchView設(shè)置了一個(gè)監(jiān)聽,當(dāng)搜索框內(nèi)容變化時(shí)耳胎,ListView動(dòng)態(tài)過濾內(nèi)容.

二惯吕、SearchView常用屬性、方法

1怕午、搜索圖標(biāo)

默認(rèn)樣式:搜索框默認(rèn)是關(guān)閉的废登,左側(cè)搜索圖標(biāo)在搜索框中,可以通過右側(cè)叉叉關(guān)閉搜索框


默認(rèn)樣式
(1)  方法SearchView.setIconified(false);

搜索框默認(rèn)是開啟的郁惜,左側(cè)搜索圖標(biāo)在搜索框中堡距,可以通過右側(cè)叉叉關(guān)閉搜索框
setIconified(false)
(2)  方法SearchView.setIconifiedByDefault(false);
或者屬性app:iconifiedByDefault="false"

搜索框默認(rèn)是開啟的,左側(cè)搜索圖標(biāo)在搜索框外
  右側(cè)一開始沒有叉叉,有輸入內(nèi)容后出現(xiàn)叉叉羽戒,叉叉只能清除搜索框內(nèi)容缤沦,無法關(guān)閉搜索框
app:iconifiedByDefault="false"
(3)  修改搜索圖標(biāo)
 app:searchIcon=""  
2、搜索框中提示內(nèi)容
app:queryHint=" "
或者方法:SearchView.setQueryHint(...)
3易稠、關(guān)閉圖標(biāo)(就是那個(gè)叉叉)
app:closeIcon=" "
4缸废、搜索框展開時(shí)顯示提交按鈕
SearchView.setSubmitButtonEnabled(true);
5、事件監(jiān)聽
    //搜索圖標(biāo)按鈕的點(diǎn)擊事件
    mSearchView.setOnSearchClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            Toast.makeText(MainActivity.this, "打開搜索框", Toast.LENGTH_SHORT).show();
        }
    });


    //搜索框內(nèi)容變化監(jiān)聽
    mSearchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
        @Override
        public boolean onQueryTextSubmit(String query) {//點(diǎn)擊提交按鈕時(shí)
            Toast.makeText(MainActivity.this, "Submit---提交", Toast.LENGTH_SHORT).show();
            return true;
        }

        @Override
        public boolean onQueryTextChange(String newText) {//搜索框內(nèi)容變化時(shí)
            if (!TextUtils.isEmpty(newText)) {
//              mListView.setFilterText(newText);
                mAdapter.getFilter().filter(newText);
            } else {
                mListView.clearTextFilter();
            }
            return true;
        }
    });

    //搜索框展開時(shí)點(diǎn)擊叉叉按鈕關(guān)閉搜索框的點(diǎn)擊事件
    mSearchView.setOnCloseListener(new SearchView.OnCloseListener() {
        @Override
        public boolean onClose() {
            Toast.makeText(MainActivity.this, "關(guān)閉搜索框", Toast.LENGTH_SHORT).show();
            return false;
        }
    });

三驶社、搭配Toolbar使用

SearchView搭配Toolbar也是非常常見的一種使用方式.

1企量、方式一

布局文件

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

    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="?attr/colorPrimary"
        app:titleTextColor="@android:color/white" />

</LinearLayout>

菜單文件

<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">
    <item
        android:id="@+id/item_searchview"
        android:title="沒什么鳥用的title"
        app:actionViewClass="android.support.v7.widget.SearchView"
        app:showAsAction="always" />
</menu>

Activity中

public class MainActivity extends AppCompatActivity {

    private SearchView mSearchView;
    private Toolbar mToolbar;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mToolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(mToolbar);
    }

    /**
     * 重寫此方法顯示Menu Item
     */
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.my_menu, menu);
        MenuItem menuItem = menu.findItem(R.id.item_searchview);
        //通過MenuItem得到SearchView
        mSearchView = (SearchView) MenuItemCompat.getActionView(menuItem);
        return true;
    }
}

1)這個(gè)menu item跟普通item的差別在于使用了app:actionViewClass屬性,app:actionViewClass="android.support.v7.widget.SearchView"表明使用了v7包下的SearchView.

2)注意:這里我們使用的是v7包下的SearchView衬吆,所以不要寫成android:actionViewClass="android.widget.SearchView".

3)這里的title并沒有什么鳥用梁钾,因?yàn)槭褂盟阉鞴δ軙r(shí)我們一般不會(huì)把它放進(jìn)溢出菜單中,但是不寫是會(huì)報(bào)錯(cuò)的.

4)如果在android:showAsAction屬性中加上collapseActionView屬性逊抡,那么MenuItem的icon屬性必須就要加上了姆泻,不然會(huì)顯示title文字的.
同時(shí)點(diǎn)開后的樣式也不一樣了,左側(cè)會(huì)出現(xiàn)一個(gè)箭頭冒嫡,點(diǎn)擊箭頭退出搜索模式.

<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">
    <item
        android:id="@+id/item_searchview"
        android:title="沒什么鳥用的title"
        app:actionViewClass="android.support.v7.widget.SearchView"
        android:icon="@drawable/icon_search"
        app:showAsAction="always|collapseActionView" />
</menu>
2拇勃、方式二

因?yàn)門oolbar本身是一個(gè)ViewGroup,可以添加子View孝凌,所以我們可以把SearchView當(dāng)做子View添加到Toolbar上.
布局文件

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

    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="?attr/colorPrimary"
        app:titleTextColor="@android:color/white" >

        <android.support.v7.widget.SearchView
            android:id="@+id/searview"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="right"
            app:queryHint="請(qǐng)輸入搜索內(nèi)容" />
    </android.support.v7.widget.Toolbar>>

</LinearLayout>

Activity中

public class MainActivity extends AppCompatActivity {

    private SearchView mSearchView;
    private Toolbar mToolbar;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mToolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(mToolbar);
        mSearchView = (SearchView) mToolbar.findViewById(R.id.searview);
        // do something
    }
}

四方咆、修改SearchView樣式

觀看SearchView源碼可以發(fā)現(xiàn),SearchView本身布局是通過xml布局文件來實(shí)現(xiàn)的.

    public SearchView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);

        ......
        final LayoutInflater inflater = LayoutInflater.from(context);
        final int layoutResId = a.getResourceId(
                R.styleable.SearchView_layout, R.layout.abc_search_view); //☆  看這里
        inflater.inflate(layoutResId, this, true); 

        mSearchSrcTextView = (SearchAutoComplete) findViewById(R.id.search_src_text);
        mSearchSrcTextView.setSearchView(this);

        mSearchEditFrame = findViewById(R.id.search_edit_frame);
        mSearchPlate = findViewById(R.id.search_plate);
        mSubmitArea = findViewById(R.id.submit_area);
        mSearchButton = (ImageView) findViewById(R.id.search_button);
        mGoButton = (ImageView) findViewById(R.id.search_go_btn);
        mCloseButton = (ImageView) findViewById(R.id.search_close_btn);
        mVoiceButton = (ImageView) findViewById(R.id.search_voice_btn);
        mCollapsedIcon = (ImageView) findViewById(R.id.search_mag_icon);
        ......
    }

找到那個(gè)布局文件

<?xml version="1.0" encoding="utf-8"?>
<!--
/*
 * Copyright (C) 2010 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

-->
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/search_bar"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="horizontal">

    <!-- This is actually used for the badge icon *or* the badge label (or neither) -->
    <TextView
        android:id="@+id/search_badge"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:gravity="center_vertical"
        android:layout_marginBottom="2dip"
        android:drawablePadding="0dip"
        android:textAppearance="?attr/textAppearanceMedium"
        android:textColor="?attr/textColorPrimary"
        android:visibility="gone" />

    <ImageView
        android:id="@+id/search_button"
        style="?attr/actionButtonStyle"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_gravity="center_vertical"
        android:focusable="true"
        android:contentDescription="@string/searchview_description_search" />

    <LinearLayout
        android:id="@+id/search_edit_frame"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:layout_marginStart="8dip"
        android:layout_marginEnd="8dip"
        android:orientation="horizontal"
        android:layoutDirection="locale">

        <ImageView
            android:id="@+id/search_mag_icon"
            android:layout_width="@dimen/dropdownitem_icon_width"
            android:layout_height="wrap_content"
            android:scaleType="centerInside"
            android:layout_marginStart="@dimen/dropdownitem_text_padding_left"
            android:layout_gravity="center_vertical"
            android:visibility="gone" />

        <!-- Inner layout contains the app icon, button(s) and EditText -->
        <LinearLayout
            android:id="@+id/search_plate"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:layout_gravity="center_vertical"
            android:orientation="horizontal">

            <view class="android.widget.SearchView$SearchAutoComplete"
                android:id="@+id/search_src_text"
                android:layout_height="36dip"
                android:layout_width="0dp"
                android:layout_weight="1"
                android:layout_gravity="center_vertical"
                android:paddingStart="@dimen/dropdownitem_text_padding_left"
                android:paddingEnd="@dimen/dropdownitem_text_padding_right"
                android:singleLine="true"
                android:ellipsize="end"
                android:background="@null"
                android:inputType="text|textAutoComplete|textNoSuggestions"
                android:imeOptions="actionSearch"
                android:dropDownHeight="wrap_content"
                android:dropDownAnchor="@id/search_edit_frame"
                android:dropDownVerticalOffset="0dip"
                android:dropDownHorizontalOffset="0dip" />

            <ImageView
                android:id="@+id/search_close_btn"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:paddingStart="8dip"
                android:paddingEnd="8dip"
                android:layout_gravity="center_vertical"
                android:background="?attr/selectableItemBackgroundBorderless"
                android:focusable="true"
                android:contentDescription="@string/searchview_description_clear" />

        </LinearLayout>

        <LinearLayout
            android:id="@+id/submit_area"
            android:orientation="horizontal"
            android:layout_width="wrap_content"
            android:layout_height="match_parent">

            <ImageView
                android:id="@+id/search_go_btn"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:layout_gravity="center_vertical"
                android:paddingStart="16dip"
                android:paddingEnd="16dip"
                android:background="?attr/selectableItemBackgroundBorderless"
                android:visibility="gone"
                android:focusable="true"
                android:contentDescription="@string/searchview_description_submit" />

            <ImageView
                android:id="@+id/search_voice_btn"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:layout_gravity="center_vertical"
                android:paddingStart="16dip"
                android:paddingEnd="16dip"
                android:background="?attr/selectableItemBackgroundBorderless"
                android:visibility="gone"
                android:focusable="true"
                android:contentDescription="@string/searchview_description_voice" />
        </LinearLayout>
    </LinearLayout>
</LinearLayout>

ok蟀架,既然是一個(gè)布局文件瓣赂,而且每一個(gè)組件都有id,那么直接通過SearchView.findViewById()找到你想要改變的組件片拍,然后設(shè)置你想要的樣式不就可以了.

方式1 :代碼修改
    //搜索框
    SearchView.SearchAutoComplete tv = (SearchView.SearchAutoComplete) mSearchView.findViewById(R.id.search_src_text);
    tv.setTextColor(Color.WHITE);
    tv.setHintTextColor(Color.WHITE);
    //搜索按鈕
    ImageView ivSearch1 = (ImageView) mSearchView.findViewById(R.id.search_button);
    ivSearch1.setImageResource(R.drawable.a);
    //關(guān)閉按鈕
    ImageView ivClose = (ImageView) mSearchView.findViewById(R.id.search_close_btn);
    ivClose.setImageResource(R.drawable.b); 

更多的樣式你可以自己去設(shè)置煌集,這里就不一一設(shè)置了.

方式2:style修改

原生的SearchView樣式像下面這樣:

    <style name="Base.Widget.AppCompat.SearchView" parent="android:Widget">
        <item name="layout">@layout/abc_search_view</item>
        <item name="queryBackground">@drawable/abc_textfield_search_material</item>
        <item name="submitBackground">@drawable/abc_textfield_search_material</item>
        <item name="closeIcon">@drawable/abc_ic_clear_material</item>
        <item name="searchIcon">@drawable/abc_ic_search_api_material</item>
        <item name="searchHintIcon">@drawable/abc_ic_search_api_material</item>
        <item name="goIcon">@drawable/abc_ic_go_search_api_material</item>
        <item name="voiceIcon">@drawable/abc_ic_voice_search_api_material</item>
        <item name="commitIcon">@drawable/abc_ic_commit_search_api_mtrl_alpha</item>
        <item name="suggestionRowLayout">@layout/abc_search_dropdown_item_icons_2line</item>
    </style>

我們可以在上面做一些修改:

    <style name="MySearchViewStyle" parent="Widget.AppCompat.SearchView">
        <item name="android:layout">@layout/abc_search_view</item>
        <item name="queryBackground">@drawable/abc_textfield_search_material</item>
        <item name="submitBackground">@drawable/abc_textfield_search_material</item>
        <item name="closeIcon">@drawable/abc_ic_clear_material</item>
        <item name="searchIcon">@drawable/abc_ic_search_api_material</item>
        <item name="goIcon">@drawable/abc_ic_go_search_api_material</item>
        <item name="voiceIcon">@drawable/abc_ic_voice_search_api_material</item>
        <item name="commitIcon">@drawable/abc_ic_commit_search_api_mtrl_alpha</item>
        <item name="suggestionRowLayout">@layout/abc_search_dropdown_item_icons_2line</item>

        <item name="defaultQueryHint">請(qǐng)輸入搜索內(nèi)容</item>
        <item name="searchHintIcon">@drawable/icon_search</item>
    </style>

然后引用該樣式即可,想要全局修改直接放在主題style中:

<item name="searchViewStyle">@style/MySearchViewStyle</item>

只想修改某一個(gè)的話給那個(gè)SearchView引用即可

style="@style/MySearchViewStyle"
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末捌省,一起剝皮案震驚了整個(gè)濱河市苫纤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌纲缓,老刑警劉巖卷拘,帶你破解...
    沈念sama閱讀 216,843評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異祝高,居然都是意外死亡栗弟,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門工闺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來乍赫,“玉大人颓屑,你說我怎么就攤上這事」⒑福” “怎么了?”我有些...
    開封第一講書人閱讀 163,187評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵遍搞,是天一觀的道長罗侯。 經(jīng)常有香客問我,道長溪猿,這世上最難降的妖魔是什么钩杰? 我笑而不...
    開封第一講書人閱讀 58,264評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮诊县,結(jié)果婚禮上讲弄,老公的妹妹穿的比我還像新娘。我一直安慰自己依痊,他們只是感情好避除,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,289評(píng)論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著胸嘁,像睡著了一般瓶摆。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上性宏,一...
    開封第一講書人閱讀 51,231評(píng)論 1 299
  • 那天群井,我揣著相機(jī)與錄音,去河邊找鬼毫胜。 笑死书斜,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的酵使。 我是一名探鬼主播荐吉,決...
    沈念sama閱讀 40,116評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼凝化!你這毒婦竟也來了稍坯?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,945評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤搓劫,失蹤者是張志新(化名)和其女友劉穎瞧哟,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體枪向,經(jīng)...
    沈念sama閱讀 45,367評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡勤揩,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,581評(píng)論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了秘蛔。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片陨亡。...
    茶點(diǎn)故事閱讀 39,754評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡傍衡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出负蠕,到底是詐尸還是另有隱情蛙埂,我是刑警寧澤,帶...
    沈念sama閱讀 35,458評(píng)論 5 344
  • 正文 年R本政府宣布遮糖,位于F島的核電站绣的,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏欲账。R本人自食惡果不足惜屡江,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,068評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望赛不。 院中可真熱鬧惩嘉,春花似錦、人聲如沸踢故。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽畴椰。三九已至臊诊,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間斜脂,已是汗流浹背抓艳。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評(píng)論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留帚戳,地道東北人玷或。 一個(gè)月前我還...
    沈念sama閱讀 47,797評(píng)論 2 369
  • 正文 我出身青樓,卻偏偏與公主長得像片任,于是被迫代替她去往敵國和親偏友。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,654評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,085評(píng)論 25 707
  • afinalAfinal是一個(gè)android的ioc对供,orm框架 https://github.com/yangf...
    passiontim閱讀 15,429評(píng)論 2 45
  • 一年一度的教師節(jié)又到了。 而最好的禮物京景,莫過于對(duì)老師的尊重窿冯。 孫文光是安徽師范大學(xué)的教授。孫教授夫妻倆和...
    拂去心塵閱讀 1,536評(píng)論 2 2
  • 有些圖片确徙,能讓你感覺心靈杯凈化一般醒串,慢慢欣賞
    黑白律動(dòng)閱讀 3,173評(píng)論 0 0
  • 處在分岔路口执桌,一條是自己喜歡的,一條是要變成自己不喜歡的那種人芜赌;而這種人又能適應(yīng)社會(huì)的發(fā)展仰挣,他們圓滑,功利缠沈,但卻能...
    靜晴微笑閱讀 184評(píng)論 0 0