Android布局控件DrawerLayout實(shí)現(xiàn)完美側(cè)滑效果
drawerLayout其實(shí)是一個(gè)布局控件,跟LinearLayout等控件是一樣的,但是drawerLayout帶有滑動(dòng)的功能。只要按照drawerLayout的規(guī)定布局方式寫完布局,就能有側(cè)滑的效果。
1)在DrawerLayout中,第一個(gè)子View必須是顯示內(nèi)容的view,并且設(shè)置它的layout_width和layout_height屬性是match_parent.
2)第二個(gè)view是抽屜view,并且設(shè)置屬性layout_gravity="left|right",表示是從左邊滑出還是右邊滑出。設(shè)置它的layout_height="match_parent"
ActionBarDrawerToggle就是DrawerLayout事件的監(jiān)聽器。
ActionBarDrawerToggle有3個(gè)方法可以被復(fù)寫,分別用來實(shí)現(xiàn)DrawerLayout打開,關(guān)閉,滑動(dòng)的事件監(jiān)聽:
- onDrawerOpened DrawerLayout滑出時(shí)調(diào)用
- onDrawerClosed DrawerLayout關(guān)閉時(shí)調(diào)用
- onDrawerSlide DrawerLayout滑動(dòng)時(shí)調(diào)用
drawerLayout布局代碼:
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/drawer_layout" > //主內(nèi)容 <FrameLayout android:id="@+id/content_frame" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:gravity="center" android:id="@+id/drawer_text" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="123"/> </FrameLayout> //側(cè)滑菜單 <ListView android:id="@+id/left_drawer" android:layout_width="40dp" android:layout_height="match_parent" android:layout_gravity="start" android:choiceMode="singleChoice" android:divider="@android:color/transparent" android:dividerHeight="0dp" android:background="#111" /> </android.support.v4.widget.DrawerLayout>
mainactivity.java代碼
package com.example.wxj.drawerlayoutlearen; import android.support.v4.widget.DrawerLayout; import android.support.v7.app.ActionBarDrawerToggle; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.widget.ListView; import android.widget.TextView; public class MainActivity extends AppCompatActivity { private DrawerLayout mDrawerLayout; private TextView view; private ListView mDrawerList; private ActionBarDrawerToggle mDrawerToggle; private CharSequence mDrawerTitle; private CharSequence mTitle; private String[] mPlanetTitles; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mDrawerLayout = (DrawerLayout)findViewById(R.id.drawer_layout); view = (TextView)findViewById(R.id.drawer_text); mDrawerToggle = new ActionBarDrawerToggle( this, mDrawerLayout, R.string.open, R.string.close ){ @Override public void onDrawerClosed(View drawerView) { super.onDrawerClosed(drawerView); view.setText("close"); } @Override public void onDrawerOpened(View drawerView) { super.onDrawerOpened(drawerView); view.setText("dakai"); } @Override public void onDrawerSlide(View drawerView, float slideOffset) { super.onDrawerSlide(drawerView, slideOffset); view.setText("huachu"); } }; mDrawerLayout.setDrawerListener(mDrawerToggle); } }
string.xml代碼
<resources> <string name="app_name">DrawerLayoutlearen</string> <string name="open" /> <string name="close" /> </resources>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android實(shí)現(xiàn)簡(jiǎn)單手機(jī)震動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)手機(jī)震動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09Android使alertDialog.builder不會(huì)點(diǎn)擊外面和按返回鍵消失的方法
本篇文章主要介紹了Android使alertDialog.builder不會(huì)點(diǎn)擊外面和按返回鍵消失的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-01-01Android中分析Jetpack?Compose動(dòng)畫內(nèi)部的實(shí)現(xiàn)原理
這篇文章主要介紹了Android中分析Jetpack?Compose動(dòng)畫內(nèi)部的實(shí)現(xiàn)原理,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下2022-09-09Android中使用的定時(shí)針(刷新頁(yè)面請(qǐng)求服務(wù)器)詳解
這篇文章主要介紹了Android中使用的定時(shí)針(刷新頁(yè)面請(qǐng)求服務(wù)器)詳解的相關(guān)資料,需要的朋友可以參考下2016-12-12Android組件Glide實(shí)現(xiàn)圖片平滑滾動(dòng)效果
這篇文章主要介紹了Android組件Glide實(shí)現(xiàn)圖片平滑滾動(dòng)效果的相關(guān)資料,具有一定的參考價(jià)值,需要的朋友可以參考下2016-07-07Android利用ViewPager實(shí)現(xiàn)可滑動(dòng)放大縮小畫廊效果
這篇文章主要介紹了Android利用ViewPager實(shí)現(xiàn)可滑動(dòng)放大縮小畫廊效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08