淺談DrawerLayout抽屜效果

来源:http://www.cnblogs.com/xqxacm/archive/2016/03/25/5319258.html
-Advertisement-
Play Games

DrawerLayout是V4包下提供的一種左滑右滑抽屜佈局效果。 實現效果如下: 因為是官方提供的,所以使用起來也相對的比較簡單。 DrawerLayout 提供 1、當界面彈出的時候,主要內容區會自動背景變黑,當點擊內容區的時候,抽屜佈局會消失 2、在屏幕邊緣手勢滑動 會拉出抽屜佈局 註意:當按 ...


DrawerLayout是V4包下提供的一種左滑右滑抽屜佈局效果。

實現效果如下:

因為是官方提供的,所以使用起來也相對的比較簡單。

DrawerLayout 提供

1、當界面彈出的時候,主要內容區會自動背景變黑,當點擊內容區的時候,抽屜佈局會消失

2、在屏幕邊緣手勢滑動 會拉出抽屜佈局

註意:當按後退鍵的時候,如果抽屜佈局正在顯示,則需要關閉抽屜佈局

 

用一個簡單的Demo介紹下:

--------------------------------------------------------------------------------------------

首先佈局文件:

佈局分為三部分,左中右。中間的是APP顯示的主要內容區,然後看你個人的需求來選擇是要左邊彈出佈局,還是右邊彈出佈局。

如果選擇是左邊彈出界面還是右邊彈出界面,只要給彈出界面設設置 

android:layout_gravity="left"  或者 android:layout_gravity="right" 就可以了

 1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 2     xmlns:tools="http://schemas.android.com/tools"
 3     android:layout_width="match_parent"
 4     android:layout_height="match_parent"
 5     android:orientation="vertical"
 6     tools:context=".DrawerActivity" >
 7 
 8 
 9     <android.support.v4.widget.DrawerLayout
10         android:id="@+id/drawer_layout"
11         android:layout_width="match_parent"
12         android:layout_height="match_parent"
13         >
14 
15         <!-- The main content view -->
16      <!-- 界面主要內容佈局區 -->
17         <FrameLayout
18             android:id="@+id/content_frame"
19             android:layout_width="match_parent"
20             android:layout_height="match_parent" >
21 
22             <Button
23                 android:id="@+id/btn"
24                 android:layout_width="match_parent"
25                 android:layout_height="wrap_content"
26                 android:text="open"
27                 />
28         </FrameLayout>
29 
30         <!-- The navigation drawer -->

      <!-- 左邊彈出佈局區 -->
31 <LinearLayout 32 android:layout_width="100dp" 33 android:layout_height="match_parent" 34 android:orientation="vertical" 35 android:layout_gravity="left" 36 android:background="#fff" 37 > 38 <TextView 39 android:layout_width="wrap_content" 40 android:layout_height="wrap_content" 41 android:text="DrawerLayout抽屜效果" 42 /> 43 <TextView 44 android:layout_width="wrap_content" 45 android:layout_height="wrap_content" 46 android:text="文本" 47 /> 48 <Button 49 android:layout_width="wrap_content" 50 android:layout_height="wrap_content" 51 android:text="按鈕"/> 52 </LinearLayout> 53 54 </android.support.v4.widget.DrawerLayout> 55 </LinearLayout>

 

然後看activity代碼:

只要  mDrawerLayout.openDrawer(Gravity.LEFT);  便可以實現彈出抽屜界面

註意重寫後退按鈕響應事件,當抽屜佈局顯示的時候要先關閉抽屜佈局

public class MainActivity extends Activity {

    private DrawerLayout mDrawerLayout = null;

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

        mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
        mDrawerLayout.setDrawerLockMode(DrawerLayout.LOCK_MODE_UNLOCKED);

        Button button = (Button) findViewById(R.id.btn);
        button.setOnClickListener(new View.OnClickListener()
        {

            @Override
            public void onClick(View v)
            {
                // 按鈕按下,將抽屜打開
                mDrawerLayout.openDrawer(Gravity.LEFT);

            }
        });

        mDrawerLayout.setDrawerListener(new DrawerLayout.DrawerListener() {
            /**
             * 當抽屜滑動狀態改變的時候被調用
             * 狀態值是STATE_IDLE(閑置--0), STATE_DRAGGING(拖拽的--1), STATE_SETTLING(固定--2)中之一。
             * 抽屜打開的時候,點擊抽屜,drawer的狀態就會變成STATE_DRAGGING,然後變成STATE_IDLE
             */
            @Override
            public void onDrawerStateChanged(int arg0) {
                Log.i("drawer", "drawer的狀態:" + arg0);
            }

            /**
             * 當抽屜被滑動的時候調用此方法
             * arg1 表示 滑動的幅度(0-1)
             */
            @Override
            public void onDrawerSlide(View arg0, float arg1) {
                Log.i("drawer", arg1 + "");
            }

            /**
             * 當一個抽屜被完全打開的時候被調用
             */
            @Override
            public void onDrawerOpened(View arg0) {
                Log.i("drawer", "抽屜被完全打開了!");
            }

            /**
             * 當一個抽屜完全關閉的時候調用此方法
             */
            @Override
            public void onDrawerClosed(View arg0) {
                Log.i("drawer", "抽屜被完全關閉了!");
            }
        });


    }

    @Override
    public void onBackPressed() {
        super.onBackPressed();
        if (mDrawerLayout!=null){
            if (mDrawerLayout.isDrawerOpen(Gravity.LEFT)){
                mDrawerLayout.closeDrawers();
            }else super.onBackPressed();
        }
    }
}

 

 

有更多需求的可以看下DrawerLayout的監聽事件:

mDrawerLayout.setDrawerListener(new DrawerLayout.DrawerListener() {
            /**
             * 當抽屜滑動狀態改變的時候被調用
             * 狀態值是STATE_IDLE(閑置--0), STATE_DRAGGING(拖拽的--1), STATE_SETTLING(固定--2)中之一。
             * 抽屜打開的時候,點擊抽屜,drawer的狀態就會變成STATE_DRAGGING,然後變成STATE_IDLE
             */
            @Override
            public void onDrawerStateChanged(int arg0) {
                Log.i("drawer", "drawer的狀態:" + arg0);
            }

            /**
             * 當抽屜被滑動的時候調用此方法
             * arg1 表示 滑動的幅度(0-1)
             */
            @Override
            public void onDrawerSlide(View arg0, float arg1) {
                Log.i("drawer", arg1 + "");
            }

            /**
             * 當一個抽屜被完全打開的時候被調用
             */
            @Override
            public void onDrawerOpened(View arg0) {
                Log.i("drawer", "抽屜被完全打開了!");
            }

            /**
             * 當一個抽屜完全關閉的時候調用此方法
             */
            @Override
            public void onDrawerClosed(View arg0) {
                Log.i("drawer", "抽屜被完全關閉了!");
            }
        });

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ...
  • 1、基本概念 Model : 模型 負責處理數據的載入或者存儲,比如從網路或本地資料庫獲取數據等; View : 視圖 負責界面數據的展示,與用戶進行交互; Presenter :主持人 任命者 負責協調關係,是模型與視圖之間的橋梁,將模型與視圖分離開來。 2、MVP模式在Android項目中的使用 ...
  • 1、java 介面的作用 http://blog.csdn.net/hack_bug/article/details/7634737 2、一位Java大牛的回答 很多JAVA初級程式員對於介面存在的意義很疑惑。不知道介面到底是有什麼作用,為什麼要定義介面。 好像定義介面是提前做了個多餘的工作。下麵我 ...
  • 在一個iOS應用的生命周期中,有時候我們只需要某個類的一個實例。例如當程式啟動時,應用的狀態由UIApplication類的一個實例維護,這個實例代表了整個應用程式對象,它只能是一個實例,作用是實現應用程式中一些共用資源的訪問和狀態的保持。 下麵就是一個單例類的例子 因為基本上所有的類單例模式都差不 ...
  • 文/崢吖(簡書作者)原文鏈接:http://www.jianshu.com/p/87ef6720a096著作權歸作者所有,轉載請聯繫作者獲得授權,並標註“簡書作者”。 前言 很多blog都說ReactiveCocoa好用,然後各種秀自己如何靈活運用ReactiveCocoa,但是感覺真正缺少的是一篇 ...
  • 1.在使用單例模式時一般使用allocWithZone 因為alloc最終還是會調用allocWithZone進行分配空間 ...
  • 【Objective-C Runtime動態載入】 動態創建類Class 動態創建類Class,動態添加Class成員變數與成員函數,動態變數賦值與取值,動態函數調用等方法 a.使用objc_allocateClassPair創建一個類Class const char * className = " ...
  • 什麼是主線程? 一個iOS程式運行後,預設會開啟一條線程,稱為“主線程”或“UI線程” 主線程的主要作用 1.顯示/刷新UI界面 2.處理UI事件(比如點擊事件,滾動事件,拖拽事件) 主線程的使用註意 1.別將比較耗時的操作放在主線程中 2.耗時操作會卡在主線程中,嚴重影響UI的流暢程度 如圖,將耗 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...