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

溫馨提示×

溫馨提示×

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

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

Android開發如何實現抽屜菜單

發布時間:2021-11-15 09:05:33 來源:億速云 閱讀:202 作者:小新 欄目:開發技術

這篇文章主要介紹Android開發如何實現抽屜菜單,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

實現效果

Android開發如何實現抽屜菜單

點擊菜單圖表即可進入抽屜

Android開發如何實現抽屜菜單

代碼實現

1、打開app/build.gradle文件,在dependencies閉包中添加如下內容:

dependencies {
            compile fileTree(dir: 'libs', include: ['*.jar'])
            compile 'com.android.support:appcompat-v7:24.2.1'
            testCompile 'junit:junit:4.12'
            compile 'com.android.support:design:24.2.1'
            compile 'de.hdodenhof:circleimageview:2.1.0'
        }

2、進入想要添加抽屜的界面的layout布局

添加DrawerLayout控件

首先DrawerLayout是一個布局,在布局中允許放入兩個直接子控件,第一個子控件是主屏幕中的內容,第二個空間是滑動菜單中顯示的內容

原本的界面所有布局內容就放在第一個子控件中

<?xml version="1.0" encoding="utf-8"?>
<androidx.drawerlayout.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/drawerLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@mipmap/bk_1"
    tools:context="com.luckyxmobile.graphserviceping.MainActivity">

    <!-- 內容區 -->
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical">
        <ImageView
            android:id="@+id/setting"
            android:layout_width="56dp"
            android:layout_height="56dp"
            android:layout_marginLeft="8dp"
            android:background="@drawable/ic_baseline_menu1"
            />
        <!--    android:background="@drawable/ic_baseline_menu_24"-->
        <!--原圖標寬高 40 52-->
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_marginTop="180dp"
            android:id="@+id/graphServicePing"
            android:gravity="center"
            android:text="Graph Service Ping"
            android:textColor="#26C6DA"
            android:textSize="36dp"/>


        <LinearLayout
            android:layout_marginTop="32dp"
            android:layout_gravity="center_horizontal"
            android:background="@drawable/bloder"
            android:layout_width="match_parent"
            android:layout_height="80dp"
            android:layout_marginStart="16dp"
            android:layout_marginEnd="16dp"
            android:paddingHorizontal="4dp">
            <!--        android:paddingHorizontal="16dp"-->
<!--            android:layout_height="wrap_content"-->

            <Button
                android:minHeight="50dp"
                android:id="@+id/btn_input"
                android:layout_width="0dp"
                android:layout_weight="8"
                android:layout_height="wrap_content"
                android:textSize="20dp"
                android:layout_marginLeft="8dp"
                android:background="@null"
                />

            <Button
                android:id="@+id/btn_ping"
                android:background="@null"
                android:layout_weight="4"
                android:text="Ping!"
                android:textColor="#262626"
                android:textSize="25sp"
                android:layout_width="0dp"
                android:layout_height="80dp"
                />
<!--                android:layout_weight="2"-->
<!--            android:layout_width="50dp"-->
<!--            android:layout_height="50dp"-->
        </LinearLayout>
    </LinearLayout>
    
    <com.google.android.material.navigation.NavigationView
        android:id="@+id/nav_view"
        android:background="@mipmap/bk_1"
        android:layout_height="match_parent"
        android:layout_width="match_parent"
        android:layout_gravity="start"
        app:menu="@menu/nav_menu">
    </com.google.android.material.navigation.NavigationView>

</androidx.drawerlayout.widget.DrawerLayout>

android:layout_gravity="start"這一句很重要,一定要加上

3.NavigationView用來優化滑動菜單頁面的

menu用來在NavigationView中顯示具體的菜單項,headerLayout則用來在NavigationView中顯示頭布局(這里我只用到了menu,所以我只寫menu)

在res下如果沒有menu目錄,可以新建一個menu文件夾,然后右鍵menu->new_menu resource file

menu代碼:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:id="@+id/nav_setting"
        android:icon="@drawable/ic_launcher_setting_foreground"
        android:title="設置">
    </item>

</menu>

可以添加多個item,不要忘了引用menu

app:menu="@menu/nav_menu"

4.設置主界面菜單圖表的點擊事件

跟intent不同

setting.setOnClickListener(new View.OnClickListener() {  //設置點擊事件
            @Override
            public void onClick(View v) {
            mDrawerLayout.openDrawer(GravityCompat.START);
            }
        });

5、設置抽屜菜單item點擊事件

DrawerLayout mDrawerLayout;
  
  mDrawerLayout=findViewById(R.id.drawerLayout);

        NavigationView navView=(NavigationView)findViewById(R.id.nav_view);
        navView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener(){

            @Override
            public boolean onNavigationItemSelected(MenuItem item) {
                switch(item.getItemId()){
                    case R.id.nav_setting:
                        startActivity(new Intent(MainActivity.this, Setting.class));
                        break;
                }
                mDrawerLayout.closeDrawers();
                return false;
            }
        });

以上是“Android開發如何實現抽屜菜單”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

AI

迁西县| 陆良县| 乐至县| 蒙阴县| 乐亭县| 子长县| 江门市| 洛宁县| 永城市| 乡城县| 苍梧县| 萝北县| 台中县| 文昌市| 恭城| 璧山县| 广宗县| 年辖:市辖区| 明水县| 景宁| 乌兰浩特市| 贺州市| 临西县| 锦州市| 云梦县| 内江市| 昭觉县| 得荣县| 安岳县| 县级市| 筠连县| 宁乡县| 固始县| 南通市| 曲周县| 靖远县| 吴忠市| 年辖:市辖区| 罗山县| 潞城市| 敦煌市|