本文介紹了對話框中的自定義 ListView的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
我有一個列表視圖,在這個列表中,當點擊其中的一個項目時,它會在對話框中顯示一個自定義列表
i have a list view , inside this list when click on an item of it ,it will show a custom list inside a dialog box
對話框顯示,但它只顯示對話框的標題
the dialog shows up but its only shows the title of the dialog
這是我的代碼
case R.id.CommentNumOfLike:
dbobj = new DataBaseHandler(getContext());
Items1 = dbobj.select_HowComment();
dbobj.CloseDataBase();
Collections.reverse(Items1);
x = (Integer) view.getTag();
Log.v("value", x + "");
target = Items1.get(x).getCommentId().toString();
CommentEvents r = new CommentEvents();
r.execute(user_id, secret_id, table, target);
final Dialog dialog = new Dialog(getContext());
dialog.setContentView(R.layout.likers_list);
dialog.setTitle("List of likers");
dialog.setCanceledOnTouchOutside(true);
dbobj = new DataBaseHandler(getContext());
likeItems=dbobj.select_HowlikeComment();
dbobj.CloseDataBase();
ListView list = (ListView) dialog.findViewById(R.id.ListLikersList);
LikersCustomeAdapter adapter= new LikersCustomeAdapter(getContext(), R.layout.likerscustomelist, likeItems);
list.setAdapter(adapter);
dialog.show();
break;
這是我的適配器
public class LikersCustomeAdapter extends ArrayAdapter<LikersComment>{
Context context;
List<LikersComment> items;
Bitmap bitmap;
String imageUser = "";
String filePath_Image = "/Pictures/jehad/joj/";
public LikersCustomeAdapter(Context context, int textViewResourceId,
List<LikersComment> objects) {
super(context, textViewResourceId, objects);
// TODO Auto-generated constructor stub
this.context=context;
}
public View getView(final int position, View convertView, ViewGroup parent) {
Log.d("View likers List", "View>>>>>>>>");
likerscommentholder h = null;
View v = convertView;
Log.v("items getName", items.get(position).getName());
LayoutInflater vi = (LayoutInflater) context
.getSystemService(Activity.LAYOUT_INFLATER_SERVICE);
if (v == null) {
v = vi.inflate(R.layout.likerscustomelist,null);
h = new likerscommentholder();
h.likersimg=(ImageView)v.findViewById(R.id.likersImg);
h.likersname=(TextView)v.findViewById(R.id.likersName);
v.setTag(h);
} else {
h = (likerscommentholder) v.getTag();
}
imageUser = items.get(position).getId() + items.get(position).getRand();
boolean flag_ImagePath = Methods.checkIfImage_DirExists(filePath_Image
+ imageUser);
if (flag_ImagePath == true) {
Log.v("flag_ImagePath", String.valueOf(flag_ImagePath));
bitmap = Methods.displayBitmapImage(imageUser);
h.likersimg.setImageBitmap(bitmap);
}
h.likersname.setText(items.get(position).getName());
return v;
}
}
class likerscommentholder {
ImageView likersimg;
TextView likersname;
}
這是列表視圖
likers_list.xml
likers_list.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" >
<ListView
android:id="@+id/ListLikersList"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
</ListView>
這是自定義布局
likerscustomelist.xml
likerscustomelist.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" >
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent" >
<ImageView
android:id="@+id/likersImg"
android:layout_width="65dp"
android:layout_height="65dp"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:src="@drawable/ic_launcher" />
<TextView
android:id="@+id/likersName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_marginLeft="16dp"
android:layout_marginTop="19dp"
android:layout_toRightOf="@+id/likersImg"
android:text="Medium Text"
android:textAppearance="?android:attr/textAppearanceMedium" />
</RelativeLayout>
</LinearLayout>
推薦答案
需要使用AlertDialog.Builder
-
參考這個- 文檔
編輯 -
new AlertDialog.Builder(MyActivity.this)
.setAdapter(yourListAdapter, new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
//TODO - Code when list item is clicked (int which - is param that gives you the index of clicked item)
}
})
.setPositiveButton("Okay", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
}
})
.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
}
})
.setTitle("Dialog Title")
.setCancelable(false)
.show();
這篇關于對話框中的自定義 ListView的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!
【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!