在我们的android中下拉菜单的制作有两种的方法:

1: 一种的方式就是通过我们的布局文件的方法制作
2: 第二种方式就是通过我们的java代码的方式制作

第一种方式:
在这里插入图片描述

<?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"
    xmlns:tools="http://schemas.android.com/tools"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".dropdown">
    <Spinner
        android:entries="@array/ctype"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <!--现在的话就是我们已经创建了一个下拉列表项但是还是没有任何的显示
         所以现在的话我们要用我们的方法来定义我们的数组资源
        -->
    </Spinner>
    <Spinner
        android:id="@+id/spinner"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <!--现在的话就是我们已经创建了一个下拉列表项但是还是没有任何的显示
         所以现在的话我们要用我们的方法来定义我们的数组资源
        -->
    </Spinner>
</LinearLayout>

然后的话就是我们的xml菜单对应的布局文件:
在这里插入图片描述
java的代码部分:
在这里插入图片描述

package com.example.handle;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.widget.ArrayAdapter;
import android.widget.Spinner;

public class dropdown extends AppCompatActivity {
    private Spinner spinner;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_dropdown);
        // 然后的话就是添加我们的下拉列表框
        spinner = (Spinner) findViewById(R.id.spinner);
        // 在我们的这个位置的话创建我们的数组
        String[] ctype = new String[]{
                "创业维艰","美术","音乐","体育"
        };
        // 然后的话创建一个我们的一个数组适配器并且的话这个数组适配器使我们的字符串类型的
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item,ctype);
        // 设置我们的数组下拉时的选项的样式
        adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
        // 将我们的适配器和我们的下拉列表框关联起来
        Spinner spinner = (Spinner) findViewById(R.id.spinner);
        spinner.setAdapter(adapter);

    }
}

然后的话就是我们的效果:
在这里插入图片描述
在这里插入图片描述

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐