更新时间:2022-10-20 22:43:09
是我得到的解决方案通过在这里的所有我的答案
首先,我必须修改这个selected_row xml文件
< XML版本=1.0编码=UTF-8&GT?;
< RelativeLayout的
的xmlns:机器人=http://schemas.android.com/apk/res/android
机器人:layout_width =WRAP_CONTENT机器人:layout_height =100dip>
< TextView的Android的:layout_width =FILL_PARENT
机器人:layout_height =40PX机器人:ID =@ + ID / txtExample
机器人:TEXTSIZE =18sp机器人:文字颜色=#000000
机器人:重力=center_vertical
/>
< ImageView的机器人:layout_width =WRAP_CONTENT
机器人:layout_height =40PX机器人:ID =@ + ID / imgbeside
机器人:scaleType =中心的Android版本:layout_centerVertical =真
机器人:layout_alignParentRight =真正的机器人:SRC =@可绘制/选择器
机器人:layout_marginRight =10dip/>
和也在我的java文件我把下面的东西下面这一行
的TextView标签=(TextView中)v.findViewById(R.id.txtExample);
ImageView的mImageview =(ImageView的)v.findViewById(R.id.imgbeside);
这会为me.Ok感谢所有效应初探。
Here is the my code for the Dialog With ListView and here i also maintain the state when the user click on list it background will be fill with green as you can see in my image below
But problem that i have is below
1>I want to increase my row height .How can do?
2>and i also want to put image beside in all row is this possible?
Here is my code for all this stuff.
package com.android.listselector;
import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
import android.app.Dialog;
import android.content.Context;
import android.graphics.Color;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.AdapterView.OnItemClickListener;
public class ListSelector extends Activity {
private SelectedAdapter selectedAdapter;
private ArrayList<String> list;
private Context mContext = ListSelector.this;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// setContentView(R.layout.selected_example);
String[] items = { "lorem", "ipsum", "dolor", "sit", "amet",
"consectetuer", "adipiscing", "elit", "morbi", "vel", "ligula",
"vitae", "arcu", "aliquet", "mollis", "etiam", "vel", "erat",
"placerat", "ante", "porttitor", "sodales", "pellentesque",
"augue", "purus" };
// populate the model - a simple a list
list = new ArrayList<String>();
for (int i = 0; i < items.length; i++) {
list.add(items[i]);
}
// create our SelectedAdapter
selectedAdapter = new SelectedAdapter(this, 0, list);
selectedAdapter.setNotifyOnChange(true);
Dialog dialog = new Dialog(mContext);
dialog.setContentView(R.layout.selected_example);
dialog.setTitle("Custom Dialog");
ListView listview = (ListView) dialog.findViewById(R.id.listExample);
listview.setAdapter(selectedAdapter);
dialog.show();
listview.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> arg0, View view,
int position, long id) {
// user clicked a list item, make it "selected"
selectedAdapter.setSelectedPosition(position);
}
});
}
// move up event handler
// move down event handler
// Move selected item "up" in the ViewList.
private void moveUp() {
int selectedPos = selectedAdapter.getSelectedPosition();
if (selectedPos > 0) {
String str = list.remove(selectedPos);
list.add(selectedPos - 1, str);
// set selected position in the adapter
selectedAdapter.setSelectedPosition(selectedPos - 1);
}
}
// Move selected item "down" in the ViewList.
private void moveDown() {
int selectedPos = selectedAdapter.getSelectedPosition();
if (selectedPos < list.size() - 1) {
String str = list.remove(selectedPos);
list.add(selectedPos + 1, str);
// set selected position in the adapter
selectedAdapter.setSelectedPosition(selectedPos + 1);
}
}
public class SelectedAdapter extends ArrayAdapter<String> {
// used to keep selected position in ListView
private int selectedPos = -1; // init value for not-selected
public SelectedAdapter(Context context, int textViewResourceId,
List<String> objects) {
super(context, textViewResourceId, objects);
}
public void setSelectedPosition(int pos) {
selectedPos = pos;
// inform the view of this change
notifyDataSetChanged();
}
public int getSelectedPosition() {
return selectedPos;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View v = convertView;
// only inflate the view if it's null
if (v == null) {
LayoutInflater vi = (LayoutInflater) this.getContext()
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
v = vi.inflate(R.layout.selected_row, null);
}
// get text view
TextView label = (TextView) v.findViewById(R.id.txtExample);
// change the row color based on selected state
if (selectedPos == position) {
label.setBackgroundColor(Color.GREEN);
} else {
label.setBackgroundColor(Color.WHITE);
}
label.setText(this.getItem(position).toString());
/*
* // to use something other than .toString() MyClass myobj =
* (MyClass)this.getItem(position);
* label.setText(myobj.myReturnsString());
*/
return (v);
}
}
}
and here are the layout used in my code
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical">
<ListView
android:id="@+id/listExample"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="#CCCCCC"
android:choiceMode="singleChoice"
/>
<LinearLayout
android:orientation="horizontal"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:id="@+id/btnMoveUp"
/>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:id="@+id/btnMoveDown"
/>
</LinearLayout>
here is other one
<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent" android:layout_height="wrap_content"
android:id="@+id/txtExample" android:textSize="18sp" android:textColor="#000000"
android:background="#FF0000">
</TextView>
Yes i get solution by here all my answer
first i have to modify selected_row xml file by this
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content" android:layout_height="100dip">
<TextView android:layout_width="fill_parent"
android:layout_height="40px" android:id="@+id/txtExample"
android:textSize="18sp" android:textColor="#000000"
android:gravity="center_vertical"
/>
<ImageView android:layout_width="wrap_content"
android:layout_height="40px" android:id="@+id/imgbeside"
android:scaleType="center" android:layout_centerVertical="true"
android:layout_alignParentRight="true" android:src="@drawable/selector"
android:layout_marginRight="10dip" />
and also in my java file i put the following thing below this line
TextView label = (TextView) v.findViewById(R.id.txtExample);
ImageView mImageview = (ImageView) v.findViewById(R.id.imgbeside);
this will work for me.Ok Thanks For all reponse.