将自定义布局与 CheckedTextView 一起用于 ListView
Using a custom layout with CheckedTextView for a ListView
为了填充我的 ListView
,我使用了一个 ArrayAdapter<String>
声明如下:
myListAdapter =new ArrayAdapter<String>(getActivity(),R.layout.myView,R.id.myTextView);
。
代表我的视图布局的 xml 文件是:
<CheckedTextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/DescriptionEtape"
android:textAppearance="?android:attr/textAppearanceListItemSmall"
android:gravity="center_vertical"
android:checkMark="?android:attr/textCheckMark"
android:paddingStart="?android:attr/listPreferredItemPaddingStart"
android:paddingEnd="?android:attr/listPreferredItemPaddingEnd"
android:checked="false"/>
为了响应用户的点击,我添加了:(ListView)FragmentView.findViewById(R.id.myListView)).setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View vue, int position, long id) {
((CheckedTextView)vue.findViewById(R.id.myTextView)).setChecked(!((CheckedTextView)vue.findViewById(R.id.myTextView)).isChecked());
}
});
当我触摸 ListView
的条目并正确检查相应的条目时,onItemClick
函数被正确执行。不幸的是,另一个在点击时不可见的条目也被选中了!!!
我的代码有什么问题?
根据 Kintanpatel 的回答,CheckedTextView
已经嵌入到 LinearLayout
中,我尝试使用自定义 ArrayAdapter<String>
,getView
函数看起来像这样:
public View getView(int position,View container,ViewGroup parent){
View view;
view= super.getView(position,container,parent);
((CheckedTextView)vue.findViewById(R.id.myTextView)).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
((CheckedTextView)v).setChecked(!((CheckedTextView)v).isChecked());
}
});
return(view);
}
我仍然有同样的问题...
最好用BaseAdapter代替ArrayAdapter。
您只需要创建简单 class 并使用 BaseAdapter 进行扩展,还在布局中创建自定义单元格,最后将此适配器应用于 ListvView。
您可以使用自定义单元执行所有功能。
下面我为您创建示例。
lay_cell.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="match_parent"
android:orientation="vertical">
<CheckBox
android:id="@+id/check_box"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="CheckBox" />
</LinearLayout>
MyAdapter.java
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.CheckBox;
import android.widget.CompoundButton;
/**
* Created by sai on 14-Jul-16.
*/
public class MyAdapter extends BaseAdapter {
private Context mContext;
public MyAdapter(Context mContext) {
this.mContext = mContext;
}
@Override
public int getCount() {
return 10;//return how many cell you want to create
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
convertView = LayoutInflater.from(mContext).inflate(R.layout.lay_cell, parent, false);
final CheckBox checkBox = (CheckBox) convertView.findViewById(R.id.check_box);
checkBox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
checkBox.setChecked(true);
}
});
return convertView;
}
}
别忘了将此适配器应用于 ListView,
listview.setAdapter(new MyAdapter(context));
事实上,在查看描述 simple_list_item_checked
的 xml 文件后,我注意到没有 LinearLayout
。我从我自己的 xml 文件中抑制了它,现在一切正常!
为了填充我的 ListView
,我使用了一个 ArrayAdapter<String>
声明如下:
myListAdapter =new ArrayAdapter<String>(getActivity(),R.layout.myView,R.id.myTextView);
。
代表我的视图布局的 xml 文件是:
<CheckedTextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/DescriptionEtape"
android:textAppearance="?android:attr/textAppearanceListItemSmall"
android:gravity="center_vertical"
android:checkMark="?android:attr/textCheckMark"
android:paddingStart="?android:attr/listPreferredItemPaddingStart"
android:paddingEnd="?android:attr/listPreferredItemPaddingEnd"
android:checked="false"/>
为了响应用户的点击,我添加了:(ListView)FragmentView.findViewById(R.id.myListView)).setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View vue, int position, long id) {
((CheckedTextView)vue.findViewById(R.id.myTextView)).setChecked(!((CheckedTextView)vue.findViewById(R.id.myTextView)).isChecked());
}
});
当我触摸 ListView
的条目并正确检查相应的条目时,onItemClick
函数被正确执行。不幸的是,另一个在点击时不可见的条目也被选中了!!!
我的代码有什么问题?
根据 Kintanpatel 的回答,CheckedTextView
已经嵌入到 LinearLayout
中,我尝试使用自定义 ArrayAdapter<String>
,getView
函数看起来像这样:
public View getView(int position,View container,ViewGroup parent){
View view;
view= super.getView(position,container,parent);
((CheckedTextView)vue.findViewById(R.id.myTextView)).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
((CheckedTextView)v).setChecked(!((CheckedTextView)v).isChecked());
}
});
return(view);
}
我仍然有同样的问题...
最好用BaseAdapter代替ArrayAdapter。 您只需要创建简单 class 并使用 BaseAdapter 进行扩展,还在布局中创建自定义单元格,最后将此适配器应用于 ListvView。 您可以使用自定义单元执行所有功能。 下面我为您创建示例。
lay_cell.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="match_parent"
android:orientation="vertical">
<CheckBox
android:id="@+id/check_box"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="CheckBox" />
</LinearLayout>
MyAdapter.java
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.CheckBox;
import android.widget.CompoundButton;
/**
* Created by sai on 14-Jul-16.
*/
public class MyAdapter extends BaseAdapter {
private Context mContext;
public MyAdapter(Context mContext) {
this.mContext = mContext;
}
@Override
public int getCount() {
return 10;//return how many cell you want to create
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
convertView = LayoutInflater.from(mContext).inflate(R.layout.lay_cell, parent, false);
final CheckBox checkBox = (CheckBox) convertView.findViewById(R.id.check_box);
checkBox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
checkBox.setChecked(true);
}
});
return convertView;
}
}
别忘了将此适配器应用于 ListView,
listview.setAdapter(new MyAdapter(context));
事实上,在查看描述 simple_list_item_checked
的 xml 文件后,我注意到没有 LinearLayout
。我从我自己的 xml 文件中抑制了它,现在一切正常!