91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

android側滑菜單控件DrawerLayout使用方法詳解

發布時間:2020-10-19 06:32:20 來源:腳本之家 閱讀:208 作者:戀戀西風 欄目:移動開發

drawerLayout是Support Library包中實現了側滑菜單效果的控件,可以說drawerLayout是因為第三方控件如MenuDrawer等的出現之后,google借鑒而出現的產物。drawerLayout分為側邊菜單和主內容區兩部分,側邊菜單可以根據手勢展開與隱藏(drawerLayout自身特性),主內容區的內容可以隨著菜單的點擊而變化(這需要使用者自己實現)。

使用步驟:

創建一個DrawerLayout

為了添加導航抽屜,你需要在你的布局界面中聲明一個DrawerLayout對象作為布局的根節點。同時在DrawerLayout內部添加兩個view:

  • 添加一個View,它包含應用的主內容(當抽屜隱藏時你的主要布局);
  • 添加另一個View它包含了導航抽屜;

如下面例子所示:該布局使用了DrawerLayout它包含了兩個子節點:一個FrameLayout它包含了主要內容(在運行時將會被Fragment替換) 和 一個ListView作為導航抽屜,上面titlebar 上圖標,負責打開、關閉抽屜;

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 
 xmlns:tools="http://schemas.android.com/tools" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 > 
 <LinearLayout 
  android:orientation="horizontal" 
  android:layout_width="match_parent" 
  android:id="@+id/titleBar" 
  android:gravity="center_vertical" 
  android:background="@android:color/darker_gray" 
  android:layout_height="40dp"> 
 
  <ImageView 
   android:layout_width="wrap_content" 
   android:layout_height="wrap_content" 
   android:src="@drawable/ic_drawer" 
   android:onClick="onClickDrawerOpened" 
   android:clickable="true" 
   android:id="@+id/imageView" /> 
 </LinearLayout> 
 <android.support.v4.widget.DrawerLayout 
  android:id="@+id/drawer_layout" 
  android:layout_below="@id/titleBar" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent"> 
  <!-- The main content view --> 
 
  <FrameLayout 
   android:id="@+id/content_frame" 
 
   android:layout_width="match_parent" 
   android:layout_height="match_parent"></FrameLayout> 
 
  <!-- The navigation drawer --> 
  <ListView 
   android:id="@+id/left_drawer" 
   android:layout_width="240dp" 
   android:layout_height="match_parent" 
   android:layout_gravity="start" 
   android:background="#111" 
   android:choiceMode="singleChoice" 
   android:divider="@android:color/transparent" 
   android:dividerHeight="0dp" /> 
 </android.support.v4.widget.DrawerLayout> 
</RelativeLayout> 

上面這個例子包含了一些重要的布局技巧:

  • 主內容View(FrameLayout在最上層)必須是Drawerlayout的第一個子節點因為XML在安排這些界面的時候是按照Z軸的順序來安排的 同時 抽屜必須在主內容的頂部。
  • 主內容View被設置成匹配父View的寬和高,因為當導航抽屜隱藏的時候它要填充整個UI。
  • 導航View(ListView)必須被聲明一個水平的gravity借助屬性android:layout_gravity。為了滿足從右到左的約定,聲明它的值為”start” 代替 “left”(因此這個抽屜將會在右面呈現當布局是RTL時)
  • 在導航View聲明時:寬度用dp為單位、高度匹配父View。為了保證用戶無論怎樣都能看到主內容的一部分,導航抽屜的寬度不能超過320dp

初始化Drawer List

在你的Activity中,要做的第一件事是初始化導航抽屜的列表項。具體該怎么做根據你APP的內容來定,但是導航抽屜通常包含一個Listview,所以還需要一個相匹配的Adapter(比如 ArrayAdapter 或者 SimpleCursorAdapter)
下面的例子,告訴你該如何借助一個string array 來初始化一個導航list

public class MainActivity extends Activity { 
 private DrawerLayout mDrawerLayout; 
 private ListView mDrawerList; 
 
 private String[] mPlanetTitles; 
 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  setContentView(R.layout.activity_main); 
 
  mPlanetTitles = getResources().getStringArray(R.array.planets_array); 
  mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout); 
  mDrawerList = (ListView) findViewById(R.id.left_drawer); 
 
  // set a custom shadow that overlays the main content when the drawer opens 
  mDrawerLayout.setDrawerShadow(R.drawable.drawer_shadow, GravityCompat.START); 
  // set up the drawer's list view with items and click listener 
  mDrawerList.setAdapter(new ArrayAdapter<String>(this, 
    R.layout.drawer_list_item, mPlanetTitles)); 
  mDrawerList.setOnItemClickListener(new DrawerItemClickListener()); 
 } 
//................................ 
} 

處理導航點擊事件

當用戶選擇了抽屜列表里面的一個Item時, 系統調用onItemClickListener上的onItemClick(), 給setOnItemClickListener().
你在onItemClick()方法里面做什么, 取決于你的app實現的結構. 在下面的例子中, 選擇每一個Item都會在主要內容的布局中插入一個不同的Fragment.

private class DrawerItemClickListener implements ListView.OnItemClickListener { 
 @Override 
 public void onItemClick(AdapterView<?> parent, View view, int position, long id) { 
  selectItem(position); 
 } 
 } 
 
 private void selectItem(int position) { 
 // update the main content by replacing fragments 
 Fragment fragment = new PlanetFragment(); 
 Bundle args = new Bundle(); 
 args.putInt(PlanetFragment.ARG_PLANET_NUMBER, position); 
 fragment.setArguments(args); 
 
 FragmentManager fragmentManager = getFragmentManager(); 
 fragmentManager.beginTransaction().replace(R.id.content_frame, fragment).commit(); 
 
 // update selected item and title, then close the drawer 
 mDrawerList.setItemChecked(position, true); 
 mDrawerLayout.closeDrawer(mDrawerList); 
 } 

 打開和關閉抽屜 

使用onDrawerOpened()和onDrawerClosed () 打開和關閉抽屜:

public void onClickDrawerOpened(View drawerView) { 
 if(!mDrawerLayout.isDrawerOpen(GravityCompat.START))//if not open ,open or close; 
 { 
 mDrawerLayout.openDrawer(mDrawerList); 
 } 
 else 
 { 
 mDrawerLayout.closeDrawer(mDrawerList); 
 } 
} 

效果圖:

android側滑菜單控件DrawerLayout使用方法詳解

Demo 下載

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

海淀区| 湘西| 新干县| 衡山县| 肇庆市| 邵武市| 嘉定区| 宁波市| 太原市| 敖汉旗| 阳泉市| 明星| 望谟县| 兴山县| 古交市| 商城县| 五大连池市| 阿拉尔市| 蒲城县| 大埔县| 历史| 秦皇岛市| 临漳县| 普兰店市| 苏尼特右旗| 柳州市| 隆安县| 莲花县| 博爱县| 阜阳市| 拜泉县| 勃利县| 黎平县| 辰溪县| 上杭县| 清苑县| 蓬溪县| 武城县| 沈阳市| 文山县| 河曲县|