我有一张地图,我显示存储在db(MySQL)中的标记,每个标记都有不同的字段(例如:name,email,addres等),因为“MarkerOptions”只允许我使用“ .tittle“,”。snippet“我想要附加的一些字段被遗漏了,我现在知道我必须使用自定义信息窗来显示我想要的所有字段。我怎样才能做到这一点? 我的代码:
主:
ArrayList<HashMap<String, String>> location = null;
String url = "http://appserver.eco.mx/movil/getLanLong.php";
try {
JSONArray data = new JSONArray(getHttpGet(url));
location = new ArrayList<HashMap<String, String>>();
HashMap<String, String> map;
for(int i = 0; i < data.length(); i++){
JSONObject c = data.getJSONObject(i);
map = new HashMap<String, String>();
map.put("id", c.getString("id"));
map.put("campo_latitud", c.getString("campo_latitud"));
map.put("campo_longitud", c.getString("campo_longitud"));
map.put("campo_categoria", c.getString("campo_categoria"));
map.put("campo_estado", c.getString("campo_estado"));
location.add(map);
}
} catch (JSONException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
String campouno = "";
if(!TextUtils.isEmpty(campouno)){
double campo_latitud = Double.parseDouble(campouno);
}
//campo_latitud = Double.parseDouble(location.get(0).get("Latitude").toString());
String campodos = "";
if(!TextUtils.isEmpty(campodos)){
double campo_longitud = Double.parseDouble(campodos);
}
for (int i = 0; i < location.size(); i++) {
if(!TextUtils.isEmpty(location.get(i).get("campo_latitud").toString())&&!TextUtils.isEmpty(location.get(i).get("campo_longitud").toString())) {
campo_latitud = Double.parseDouble(location.get(i).get("campo_latitud").toString());
campo_longitud = Double.parseDouble(location.get(i).get("campo_longitud").toString());
}
String name = location.get(i).get("campo_categoria").toString();
//String des = location.get(i).get("campo_descripcion").toString();
if(location.get(i).get("campo_categoria").toString().equals("Obras publicas")){
//System.out.println(location.get(i).get("campo_descripcion").toString());
googleMap.addMarker(new MarkerOptions().position(new LatLng(campo_latitud, campo_longitud)).title(name).icon(BitmapDescriptorFactory.fromResource(R.drawable.ic_op)));
}
}}
XML:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:background="@android:color/white">
<TextView
android:id="@+id/info_window_nombre"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:paddingLeft="5dp"
android:text="Carlo Estrada Solano" />
<TextView
android:id="@+id/info_window_placas"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textStyle="bold"
android:textSize="20sp"
android:layout_below="@id/info_window_nombre"
android:paddingLeft="5dp"
android:text="Placas: SX5487" />
<TextView
android:id="@+id/info_window_estado"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/info_window_placas"
android:paddingLeft="5dp"
android:text="Estado: Activo" />
</LinearLayout>
InfoWindow类:
public class AdaptadorInforWindow implements GoogleMap.InfoWindowAdapter {
private static final String TAG = "CustomInfoWindowAdapter";
private LayoutInflater inflater;
public AdaptadorInforWindow(LayoutInflater inflater){
this.inflater = inflater;
}
@Override
public View getInfoWindow(Marker marker) {
//Carga layout personalizado.
View v = inflater.inflate(R.layout.infowindow_layout, null);
String[] info = marker.getTitle().split("&");
String url = marker.getSnippet();
((TextView)v.findViewById(R.id.info_window_nombre)).setText("Lina Cortés");
((TextView)v.findViewById(R.id.info_window_placas)).setText("Placas: SRX32");
((TextView)v.findViewById(R.id.info_window_estado)).setText("Estado: Activo");
return v;
}
@Override
public View getInfoContents(Marker marker) {
return null;
}
}
设置googlemap:
myGoogleMap.setInfoWindowAdapter(new CustomInfoWindowAdapter(LayoutInflater.from(getActivity())));
答案 0 :(得分:1)
使用标记键在Hashmap中存储标记。然后使用自定义信息窗口使用hashmap对象来检索其他信息。 当您单击标记时,它将显示相关信息。
或者您可以在病房的8:00观看此视频。 Click Here
答案 1 :(得分:0)
所以我刚为我的应用做了CustomInfoWindow
。以下是如何实现这一目标。
首先在数据库文件中创建一个方法,只是为了访问与标记相关的所有数据,代码如下:
Cursor getDetails(Marker marker){
db = getReadableDatabase();
String query = "select Name, Email, Address from YourTableName where Name = '"+marker.getTitle()+"';";
return db.rawQuery(query,null);
}
然后调整您的AdaptadorInforWindow代码,如下所示:
YourDatabaseClass db = new YourDatabaseClass(context);
Cursor c = db.getDetails(); //Method you'll create in database class
((TextView)v.findViewById(R.id.info_window_name)).setText(c.getString(0));
((TextView)v.findViewById(R.id.info_window_email)).setText(c.getString(1));
((TextView)v.findViewById(R.id.info_window_address)).setText(c.getString(2));
c.close();
请参阅使用getString
因为我猜您使用了Text / String数据类型来存储您的姓名,电子邮件和地址值。请记住,如果数据类型发生更改,则必须使用适当的方法作为c.getInt(index)
用于int等。
此外,指数0,1,2与查询中的相同:名称电子邮件地址。
这样您就可以在CustomInfoWindow
。
同样在我的工作非常好,我很确定这会奏效。