使用自定义INFOWINDOW与MySQL

时间:2017-10-20 01:52:29

标签: android mysql google-maps-markers infowindow

我有一张地图,我显示存储在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())));

2 个答案:

答案 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

中显示您的数据

同样在我的工作非常好,我很确定这会奏效。