添加多个 Textview 作为 ListView 项
Adding multiple Textviews as a ListView item
在 android 中,我试图创建一个 ListView,每个项目都是 3 个文本视图。当我 运行 我的程序时,它显示一个白页(空列表)。作为初学者,我不确定自己做错了什么。
下面是我的自定义适配器和一个自定义对象 class。
class CustomObject {
private String title;
private String date;
private String body;
public CustomObject(String prop1, String prop2, String prop3) {
this.title = prop1;
this.date = prop2;
this.body=prop3;
}
public String getTitle() {
return title;
}
public String getDate() {
return date;
}
public String getBody(){
return body;
}
}
public class CustomAdapter extends BaseAdapter {
private LayoutInflater inflater;
private ArrayList<CustomObject> objects;
private Activity activity;
private class ViewHolder {
TextView titleTextView;
TextView dateTextView;
TextView bodyTextView;
}
public CustomAdapter(Context context, ArrayList<CustomObject> objects, Activity activity) {
super();
inflater = LayoutInflater.from(context);
this.objects = objects;
this.activity= activity;
}
@Override
public int getCount() {
return objects.size();
}
@Override
public CustomObject getItem(int position) {
return objects.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
if(convertView == null) {
holder = new ViewHolder();
convertView = inflater.inflate(R.layout.activity_listview, null); //NOT SURE
holder.titleTextView = new TextView(activity);
//holder.titleTextView.setText(titleList.get(i));
holder.titleTextView.setTextSize(14);
holder.titleTextView.setTypeface(holder.titleTextView.getTypeface(), Typeface.BOLD); //title in bold
holder.titleTextView.setGravity(Gravity.RIGHT);
holder.dateTextView = new TextView(activity);
//tvDate[i].setText(dateList.get(i));
holder.dateTextView.setTextSize(14);
holder.dateTextView.setTypeface(holder.dateTextView.getTypeface(), Typeface.ITALIC); //Date in ITALIC
holder.dateTextView.setGravity(Gravity.RIGHT);
holder.bodyTextView = new TextView(activity);
//holder.bodyTextView.setText(textList.get(i));
holder.bodyTextView.setTextSize(14);
holder.bodyTextView.setGravity(Gravity.RIGHT);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
holder.titleTextView.setText(objects.get(position).getTitle());
holder.dateTextView.setText(objects.get(position).getDate());
holder.bodyTextView.setText(objects.get(position).getBody());
return convertView;
}
}
下面是创建和显示listView的方法
private void displayNews()
{
ListView listView = new ListView(activity);
//listView.setLayoutParams();
ArrayList<CustomObject> objects = new ArrayList<CustomObject>();
for(int i=0; i<titleList.size(); i++)
objects.add(new CustomObject(titleList.get(i), dateList.get(i),textList.get(i) ));
CustomAdapter customAdapter = new CustomAdapter(activity, objects, activity);
listView.setAdapter(customAdapter);
//THE WHOLE VIEW
ScrollView sv = new ScrollView(activity);
LinearLayout ll = new LinearLayout(activity);
ll.setOrientation(LinearLayout.VERTICAL);
ll.setLayoutParams(new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT, LinearLayout.LayoutParams.FILL_PARENT));
ll.setGravity(Gravity.RIGHT);
ll.addView(listView,LinearLayout.LayoutParams.FILL_PARENT, LinearLayout.LayoutParams.FILL_PARENT); //adding
sv.addView(ll);//adding the layout view to the scorllable view
activity.setContentView(sv);//adding the scrollable view to the activity :)
}
下面是activity_listview.xml
<?xml version="1.0" encoding="utf-8"?>
<!-- Single List Item Design -->
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/label"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:padding="10dip"
android:textSize="16dip"
android:textStyle="bold"
android:gravity="right">
</TextView>
如果要动态创建文本视图,则必须将它们添加到视图组。
与您在这一行中对列表视图所做的类似:
ll.addView(listView,LinearLayout.LayoutParams.FILL_PARENT, LinearLayout.LayoutParams.FILL_PARENT); //adding
只需创建新的 ViewGroup(LinearLayout、Relative Layout 等)并添加文本视图。
希望对您有所帮助!
更改 activity_listview.xml
例如如下:
<?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" >
<TextView
android:id="@+id/txtTitle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="10dip"
android:textSize="16dip"
android:textStyle="bold">
</TextView>
<TextView
android:id="@+id/txtDate"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="10dip"
android:textSize="16dip">
</TextView>
<TextView
android:id="@+id/txtBody"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="10dip"
android:textSize="16dip">
</TextView>
</LinearLayout>
更改使视图膨胀并初始化 ViewHolder
实例的代码:
holder = new ViewHolder();
convertView = inflater.inflate(R.layout.activity_listview, null);
holder.titleTextView = (TextView) convertView.findViewById(R.id.txtTitle);
holder.dateTextView = (TextView) convertView.findViewById(R.id.txtDate);
holder.bodyTextView = (TextView) convertView.findViewById(R.id.txtBody);
注意R.id.txtTitle
、R.id.txtDate
、R.id.txtBody
对应布局文件中的android:id="@+id/txtTitle"
、android:id="@+id/txtDate"
、android:id="@+id/txtBody"
(activity_listview.xml).
更新:
我编辑布局文件。您可以尝试在 Android Studio 中使用 GUI 设计布局。
在 android 中,我试图创建一个 ListView,每个项目都是 3 个文本视图。当我 运行 我的程序时,它显示一个白页(空列表)。作为初学者,我不确定自己做错了什么。
下面是我的自定义适配器和一个自定义对象 class。
class CustomObject {
private String title;
private String date;
private String body;
public CustomObject(String prop1, String prop2, String prop3) {
this.title = prop1;
this.date = prop2;
this.body=prop3;
}
public String getTitle() {
return title;
}
public String getDate() {
return date;
}
public String getBody(){
return body;
}
}
public class CustomAdapter extends BaseAdapter {
private LayoutInflater inflater;
private ArrayList<CustomObject> objects;
private Activity activity;
private class ViewHolder {
TextView titleTextView;
TextView dateTextView;
TextView bodyTextView;
}
public CustomAdapter(Context context, ArrayList<CustomObject> objects, Activity activity) {
super();
inflater = LayoutInflater.from(context);
this.objects = objects;
this.activity= activity;
}
@Override
public int getCount() {
return objects.size();
}
@Override
public CustomObject getItem(int position) {
return objects.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
if(convertView == null) {
holder = new ViewHolder();
convertView = inflater.inflate(R.layout.activity_listview, null); //NOT SURE
holder.titleTextView = new TextView(activity);
//holder.titleTextView.setText(titleList.get(i));
holder.titleTextView.setTextSize(14);
holder.titleTextView.setTypeface(holder.titleTextView.getTypeface(), Typeface.BOLD); //title in bold
holder.titleTextView.setGravity(Gravity.RIGHT);
holder.dateTextView = new TextView(activity);
//tvDate[i].setText(dateList.get(i));
holder.dateTextView.setTextSize(14);
holder.dateTextView.setTypeface(holder.dateTextView.getTypeface(), Typeface.ITALIC); //Date in ITALIC
holder.dateTextView.setGravity(Gravity.RIGHT);
holder.bodyTextView = new TextView(activity);
//holder.bodyTextView.setText(textList.get(i));
holder.bodyTextView.setTextSize(14);
holder.bodyTextView.setGravity(Gravity.RIGHT);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
holder.titleTextView.setText(objects.get(position).getTitle());
holder.dateTextView.setText(objects.get(position).getDate());
holder.bodyTextView.setText(objects.get(position).getBody());
return convertView;
}
}
下面是创建和显示listView的方法
private void displayNews()
{
ListView listView = new ListView(activity);
//listView.setLayoutParams();
ArrayList<CustomObject> objects = new ArrayList<CustomObject>();
for(int i=0; i<titleList.size(); i++)
objects.add(new CustomObject(titleList.get(i), dateList.get(i),textList.get(i) ));
CustomAdapter customAdapter = new CustomAdapter(activity, objects, activity);
listView.setAdapter(customAdapter);
//THE WHOLE VIEW
ScrollView sv = new ScrollView(activity);
LinearLayout ll = new LinearLayout(activity);
ll.setOrientation(LinearLayout.VERTICAL);
ll.setLayoutParams(new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT, LinearLayout.LayoutParams.FILL_PARENT));
ll.setGravity(Gravity.RIGHT);
ll.addView(listView,LinearLayout.LayoutParams.FILL_PARENT, LinearLayout.LayoutParams.FILL_PARENT); //adding
sv.addView(ll);//adding the layout view to the scorllable view
activity.setContentView(sv);//adding the scrollable view to the activity :)
}
下面是activity_listview.xml
<?xml version="1.0" encoding="utf-8"?>
<!-- Single List Item Design -->
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/label"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:padding="10dip"
android:textSize="16dip"
android:textStyle="bold"
android:gravity="right">
</TextView>
如果要动态创建文本视图,则必须将它们添加到视图组。 与您在这一行中对列表视图所做的类似:
ll.addView(listView,LinearLayout.LayoutParams.FILL_PARENT, LinearLayout.LayoutParams.FILL_PARENT); //adding
只需创建新的 ViewGroup(LinearLayout、Relative Layout 等)并添加文本视图。
希望对您有所帮助!
更改 activity_listview.xml
例如如下:
<?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" >
<TextView
android:id="@+id/txtTitle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="10dip"
android:textSize="16dip"
android:textStyle="bold">
</TextView>
<TextView
android:id="@+id/txtDate"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="10dip"
android:textSize="16dip">
</TextView>
<TextView
android:id="@+id/txtBody"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="10dip"
android:textSize="16dip">
</TextView>
</LinearLayout>
更改使视图膨胀并初始化 ViewHolder
实例的代码:
holder = new ViewHolder();
convertView = inflater.inflate(R.layout.activity_listview, null);
holder.titleTextView = (TextView) convertView.findViewById(R.id.txtTitle);
holder.dateTextView = (TextView) convertView.findViewById(R.id.txtDate);
holder.bodyTextView = (TextView) convertView.findViewById(R.id.txtBody);
注意R.id.txtTitle
、R.id.txtDate
、R.id.txtBody
对应布局文件中的android:id="@+id/txtTitle"
、android:id="@+id/txtDate"
、android:id="@+id/txtBody"
(activity_listview.xml).
更新:
我编辑布局文件。您可以尝试在 Android Studio 中使用 GUI 设计布局。