我正在研究android项目,我需要在其中绘制如下所示的UI。我需要将Android屏幕划分为两半。在上半部分,我需要显示谷歌地图。在下半部分,我需要在任何人点击Google地图时立即显示用户信息。上半部分完成,它为我工作。
问题陈述: -
我需要dynamically
继续在下半部分创建linear layout
,具体取决于地图上有多少markers(users)
。下面是我在谷歌地图上考虑layouts
的下半部分创建了两个two user's
的屏幕截图。但是我怎样才能让这个东西工作dynamically
,假设我当前有three user's on the google maps
,那么在下半部分三个布局将自动绘制。我希望我足够清楚。
答案 0 :(得分:0)
是的,你可以使用listview并创建自定义适配器。将您的地图设置为listview中的标题,并使用listview行进行数据表示。
您可以做的另一件事是创建列表视图和单独的地图。将下面的列表视图与地图对齐
这里我给你一个简单的例子,下面的代码将创建listview。您可能需要为自己的目的创建自定义适配器。
public class my_map_activity extends Activity {
ArrayList<String> name = null;
ArrayList<String> gender = null;
ArrayList<String> latitude = null;
ArrayList<String> longitude = null;
Context activity_context = null;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ListView user_listview = (ListView) findViewById(R.id.user_listview);
name = new ArrayList<String>();
gender = new ArrayList<String>();
latitude = new ArrayList<String>();
longitude = new ArrayList<String>();
for (int i = 0; i < 10; i++) {
name.add ("test user " + i);
gender.add ("Male");
latitude.add (""+ i);
longitude.add (""+ i);
}
custom_adapter list_adapter = new custom_adapter (this, android.R.layout.simple_list_item_1, name, gender, latitude, longitude);
user_listview.setAdapter(list_adapter);
}
}
这是我的main.xml文件。这将告诉您如何创建该布局。我使用相对布局作为我的父布局。
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/RelativeLayout1"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<ImageView
android:id="@+id/imageView1"
android:layout_width="wrap_content"
android:layout_height="250dp"
android:layout_alignParentLeft="true"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:src="@drawable/ic_launcher" />
<ListView
android:id="@+id/user_listview"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/imageView1" >
</ListView>
</RelativeLayout>
这里我发布了我的自定义适配器代码,您可以将其用于列表视图目的。
public class custom_adapter extends ArrayAdapter<String>{
ArrayList<String> name = null;
ArrayList<String> gender = null;
ArrayList<String> latitude = null;
ArrayList<String> longitude = null;
Context activity_context = null;
public custom_adapter(Context context,
int resource,
ArrayList<String> name ,
ArrayList<String> gender,
ArrayList<String> latitude,
ArrayList<String> longitude) {
super(context, resource, name );
this.name = name;
this.gender = gender;
this.latitude = latitude;
this.longitude = longitude;
activity_context = context;
}
static class ViewHolder
{
public TextView txt_name;
public TextView txt_gender;
public TextView txt_latitude;
public TextView txt_longitude;
public ImageView img_view;
}
@Override
public View getView (final int position,
View convertView,
ViewGroup parent)
{
View rowView = convertView;
ViewHolder holder = null;
if (rowView == null) {
LayoutInflater inflater = (LayoutInflater)activity_context.getSystemService(
Context.LAYOUT_INFLATER_SERVICE);
rowView = inflater.inflate(R.layout.row_file, null, false);
holder = new ViewHolder();
holder.txt_name = (TextView) rowView.findViewById(R.id.textView1);
holder.txt_gender = (TextView) rowView.findViewById(R.id.textView2);
holder.txt_latitude = (TextView) rowView.findViewById(R.id.textView3);
holder.txt_longitude = (TextView) rowView.findViewById(R.id.textView4);
holder.img_view = (ImageView) rowView.findViewById(R.id.imageView1);
rowView.setTag(holder);
} else {
holder = (ViewHolder) rowView.getTag();
}
if (holder != null) {
holder.txt_name.setText(name.get(position));
holder.txt_gender.setText(gender.get(position));
holder.txt_latitude.setText(latitude.get(position));
holder.txt_longitude.setText(longitude.get(position));
}
return rowView;
}
}
以下是您可以在自定义适配器中充气并在列表视图上设置的布局。
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/RelativeLayout1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
<ImageView
android:id="@+id/imageView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:src="@drawable/ic_launcher" android:layout_marginTop="10dp" android:layout_marginLeft="10dp" android:contentDescription="TODO"/>
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:layout_toRightOf="@+id/imageView1"
android:text="Medium Text"
android:textAppearance="?android:attr/textAppearanceMedium" />
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_below="@+id/textView1"
android:layout_toRightOf="@+id/imageView1"
android:text="Medium Text"
android:textAppearance="?android:attr/textAppearanceMedium" />
<TextView
android:id="@+id/textView3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/textView2"
android:layout_alignParentRight="true"
android:layout_below="@+id/textView2"
android:text="Medium Text"
android:textAppearance="?android:attr/textAppearanceMedium" />
<TextView
android:id="@+id/textView4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/textView3"
android:layout_alignParentRight="true"
android:layout_below="@+id/textView3"
android:text="Medium Text"
android:textAppearance="?android:attr/textAppearanceMedium" />
</RelativeLayout>
所以我给了你所有四个文件。我在这里解释每个文件将会做什么。
my_map_activity:这是包含listivew和map两者的主要活动。我正在使用一个很棒的imageview。您可以放置地图而不是该imageview。
main.xml:这是包含listview和map的布局文件。
custom_adapter:这是我为您创建的自定义适配器。我正在扩展阵列适配器。在这里我从arraylist获取数据并使行布局膨胀,我正在设置相应的值。
row_layout:这是行布局,其中包含用户,名称,性别和所有其他内容的imageview。
所以,如果您需要任何帮助,我已经为您创建了几件事情,那么您可以询问并尝试获取每个文件的概念我的使用方式。