gpt4 book ai didi

android - 如何在Android的子菜单中选择多个复选框?

转载 作者:塔克拉玛干 更新时间:2023-11-02 19:58:26 25 4
gpt4 key购买 nike

我有一个带有“添加/删除”选项的选项菜单,单击该选项时会显示一个可检查列表。我目前拥有的代码的问题是您一次只能选择一项,并且菜单消失。我希望能够一次检查列表中的多个项目,并且在用户触摸屏幕上其他地方的某个位置之前它不会消失。我怎样才能做到这一点?这是我所拥有的一般想法:

<?xml version="1.0" encoding="UTF-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@+id/select_options"
android:title="Add/Remove">
<menu>
<group android:checkableBehavior="all">
<item android:id="@+id/A"
android:checked="true"
android:title="Option One" />
<item android:id="@+id/B"
android:checked="true"
android:title="Option Two" />
</group>
</menu>
</item>
</menu>


@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.selection_menu, menu);
return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item){
switch (item.getItemId()){
case R.id.A:
item.setChecked(!item.isChecked());
return true;
case R.id.B:
item.setChecked(!item.isChecked());
return true;
default:
return super.onOptionsItemSelected(item);
}
}

最佳答案

你好 TheBeatlemaniac!

老实说,我不知道您要寻找的东西是否可行(编辑:按照您实现它的方式,作为子菜单),但我会这样做:

创建一个看起来像您要显示的子菜单的 Activity 。

它可能看起来有点复杂,但它是直截了当的,通过这种方式,如果您选择/取消选择一个项目,它不会消失,并且您可以实现更多功能。

以下是我个人的做法:

  • 创建一个类来表示子菜单项。它应该包含一个字符串(描述)和一个 bool 值(存储是否被选中)。

  • public class SettingCheckBox implements Serializable {

    private static final long serialVersionUID = 1L;

    private static final String DEFAULT_DESCRIPTION = "N/A";

    private final String description;

    private boolean checked;

    public String getDescription () {
    return description == null ? DEFAULT_DESCRIPTION : description;
    }

    public void setChecked ( final boolean checked ) {
    this.checked = checked;
    }

    public boolean getChecked () {
    return checked;
    }

    public SettingCheckBox ( final String description ) {
    this.description = description;
    }

    }

    如您所见,该类实现了 Serializable,以便该类的对象可以使用 Intent/bundle 从一个 Activity 传递到另一个 Activity 。
  • 将以下内容添加到您当前的 Activity 中(我假设它名为 MainActivity ,因此在您尝试时,将 MainActivity 替换为您的 Activity 名称)。

  • public static final String SETTING_CHECK_BOX = "SETTING_CHECK_BOX";

    private ArrayList < SettingCheckBox > settingList;

    @Override
    public void onCreate(Bundle savedInstanceState) {
    // ...
    settingList = new ArrayList < SettingCheckBox > ();
    settingList.add ( new SettingCheckBox ( "Option A" ) );
    settingList.add ( new SettingCheckBox ( "Option B" ) );
    // ... add more items
    // restore any previously saved list
    if ( savedInstanceState != null ) {
    settingList = (ArrayList < SettingCheckBox >) savedInstanceState.getSerializable ( SETTING_CHECK_BOX );
    }
    // ...
    }

    protected void onSaveInstanceState ( Bundle outState ) {
    super.onSaveInstanceState ( outState );
    outState.putSerializable ( SETTING_CHECK_BOX , settingList );
    }

    列表 (ArrayList) 用于托管所有带有复选框的设置子菜单项。
    如您所见,每个 设置复选框对象具有描述和状态(选中或未选中)。默认情况下,一旦创建,对象状态是未选中的。
    您应该初始化 中的列表onCreate 方法。

    静态和最终变量 SETTING_CHECK_BOX 用作在 Activity 重新创建之前/之后保存/恢复该列表内容的键(如屏幕旋转),以及将设置列表从一个 Activity 传递到另一个 Activity 。 (稍后解释)
  • 删除您的子菜单,以便菜单 xml 文件如下所示:

  • <?xml version="1.0" encoding="UTF-8"?>
    <menu xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:id="@+id/select_options"
    android:title="Add/Remove">
    </item>
    </menu>

    不再需要子菜单,因为您将实现一个行为类似的 Activity 。
    现在,要将菜单项链接到将显示设置的 Activity ,您应该使用 onOptionsItemSelected 您当前 Activity 中的方法如下:

    @Override
    public boolean onOptionsItemSelected ( MenuItem menuItem ) {
    if ( menuItem.getItemId () == R.id.select_options ) {
    Intent intent = new Intent ( this , MyActivity_Settings.class );
    intent.putExtra ( SETTING_CHECK_BOX , settingList );
    startActivityForResult ( intent , 0 );
    }
    }

    设置 Activity 为结果而启动。这意味着它就像一个子 Activity ,并且可以将结果返回给其父 Activity 。

    设置列表通过 Intent 传递给设置 Activity 。

    如果子 Activity 结束并向父 Activity 返回数据,则调用以下方法:

    protected void onActivityResult ( int requestCode , int resultCode , Intent data ) {
    if ( resultCode != RESULT_OK || data == null )
    return;
    settingList = (ArrayList < SettingCheckBox >) data.getSerializableExtra ( SETTING_CHECK_BOX );
    }

    您应该让子/设置 Activity 返回(新的/修改的)设置列表,并且如上所示,新列表已设置。
  • 创建以下名为 sub_menu 的布局 xml 文件:

  • <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <ListView
    android:id="@android:id/list"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" >
    </ListView>

    </LinearLayout>

    这是将作为您的子菜单的 Activity 的布局。它实际上是一个列表 Activity ,并且可以包含任意数量的选项(您只需将它们添加到上面 Activity 中声明的数组列表中)。
  • 创建以下名为 sub_menu_item 的布局 xml 文件:

  • <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal"
    android:gravity="center_vertical" >

    <TextView
    android:id="@+id/option_title"
    android:layout_width="0dip"
    android:layout_height="wrap_content"
    android:layout_weight="1"
    android:textAppearance="@android:style/TextAppearance.Medium" />

    <CheckBox
    android:id="@+id/option_checkbox"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" />

    </LinearLayout>

    这是列表中每一行的布局,有一个 TextView 和复选框(就像您已经使用的子菜单)。
  • 创建一个名为 MyActivity_Settings 的新类,应包含以下内容:

  • public class MyActivity_Settings extends ListActivity {

    private ArrayList < SettingCheckBox > settingList;

    @Override
    public void onCreate ( Bundle savedInstanceState ) {
    super.onCreate(savedInstanceState);
    setContentView ( R.layout.sub_menu );
    setTitle ( "Add/Remove" );
    settingList = getIntent ().getSerializableExtra ( MainActivity.SETTING_CHECK_BOX );
    if ( savedInstanceState != null ) {
    settingList = (ArrayList < SettingCheckBox >) savedInstanceState.getSerializable ( MainActivity.SETTING_CHECK_BOX );
    }
    setListAdapter ( new MyActivity_Settings_Adapter ( this , R.layout.item_layout , settingList ) );
    }

    protected void onSaveInstanceState ( Bundle outState ) {
    super.onSaveInstanceState ( outState );
    outState.putSerializable ( MainActivity.SETTING_CHECK_BOX , settingList );
    }

    @Override
    public void finish () {
    setResult ( RESULT_OK , new Intent ().putExtra ( MainActivity.SETTING_CHECK_BOX , settingList ) );
    super.finish ();
    }

    }

    class MyActivity_Settings_Adapter extends ArrayAdapter < SettingCheckBox > {

    private final LayoutInflater layoutInflater;
    private final int itemResourceId;

    // Holder pattern (used instead of findViewById for better performance)
    static class ViewHolder {
    public TextView title;
    public CheckBox checkBox;
    }

    // Constructor
    public MyActivity_Settings_Adapter ( ListActivity context, int itemResourceId , List < SettingCheckBox > options ) {
    super ( context , itemResourceId , options );
    layoutInflater = context.getLayoutInflater ();
    this.itemResourceId = itemResourceId;
    }

    // Method called by the list view every time to display a row
    @Override
    public View getView ( int position , View convertView , ViewGroup parent ) {
    // Declare and initialize the row view
    View rowView = convertView;
    // Declare the row view holder
    ViewHolder viewHolder;
    // Check if an inflated view is provided
    if ( rowView == null ) {
    // A new view must be inflated
    rowView = layoutInflater.inflate ( itemResourceId , null );
    // Declare and initialize a view holder
    viewHolder = new ViewHolder ();
    // Retrieve a reference to the row title
    viewHolder.title = (TextView) rowView.findViewById ( R.id.option_title );
    // Retrieve a reference to the row check box
    viewHolder.checkBox = (CheckBox) rowView.findViewById ( R.id.option_checkbox );
    // Store the view holder as tag
    rowView.setTag ( viewHolder );
    } // End if
    else
    // An inflated view is already provided, retrieve the stored view holder
    viewHolder = (ViewHolder) rowView.getTag ();

    // Set the option title
    viewHolder.title.setText ( getItem ( position ).getDescription () );
    // Set the option check box state
    viewHolder.checkBox.setChecked ( getItem ( position ).getChecked () );
    // Assign a click listener to the checkbox
    viewHolder.checkBox.setOnClickListener( new OnClickListener() {

    public void onClick ( View checkBox ) {
    // Retrieve the stored view holder
    ViewHolder viewHolder = (ViewHolder) ((View) checkBox.getParent()).getTag();
    // Update the option state
    getItem ( position ).setChecked ( ! getItem ( position ).getChecked () );
    // Display the new option state
    viewHolder.checkBox.setChecked ( getItem ( position ).getChecked () );
    }
    });

    // Return the row view for display
    return rowView;
    } // End of getView

    }

    此类代表将充当您的子菜单的 Activity 。正如我之前所说,它是一个 List Activity(因此应该扩展 ListActivity)。为了显示列表中的各种选项,您需要一个适配器(对于这种情况,数组适配器就足够了),这就是 MyActivity_Settings_Adapter 类(扩展 ArrayAdapter )的作用。

    如果列表 Activity 完成(用户单击后退按钮,或显示为对话框的 Activity 之外的任何地方),它( Activity )将带有新选中值的新选项列表返回给父 Activity 。

    适配器将为要显示的列表构建每一行。
    此外,适配器将为每个复选框分配一个单击监听器,以便如果选中(或未选中)该选项将相应地进行修改。

    如果您单击子菜单外的任何位置(或简单地按下后退按钮),子菜单将消失,并且用户选择将保留在主 Activity 的 bool 数组中。

    如果你不熟悉 ListActivity 和 ArrayAdapter,这个 tutorial会有很大帮助!
  • 不要忘记将其添加到您的 android manifest xml 文件中(在应用程序标签中):

  •     <activity android:name=".MyActivity_Settings"
    android:theme="@android:style/Theme.Dialog" />

    应用的主题 (@android:style/Theme.Dialog) 将使 Activity 看起来像一个子菜单。

    希望能帮助到你 !
    我试过了,效果很好!试试吧,让我知道会发生什么。

    关于android - 如何在Android的子菜单中选择多个复选框?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7072347/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com