我正在使用Polaris Library for Android Maps,因为它具有群集支持: Polaris with Clustering. 我不依赖谷歌地图V2,因为它会使我的目标远离许多设备。
我需要做的是能够个性化气球中显示的信息。 当用户点击标记时,应该显示一个气球,左边是图片,中间是4行文字,右边是另一个。
我与Polaris创建者交换了几封邮件,由于显而易见的原因,他无法全力支持每个使用他的图书馆的开发人员。他暗示我使用MapCalloutView #setCustomView,但我无法理解。
提前谢谢。
答案 0 :(得分:0)
我终于成功了。
首先,我扩展了Annotation以添加其他字段:
public class CustomAnnotation extends Annotation {
private CustomObject cObject;
public CustomObject getCustomObject() {
return cObject;
}
public void setCustomObject(CustomObject cObject) {
this.cObject = cObject;
}
public CustomAnnotation(GeoPoint point, String title, String snippet,CustomObject cObject) {
super(point, title, snippet);
this.cObject = cObject;
}
我为CallOutView创建了一个布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/content"
android:paddingLeft="5dip"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical">
<LinearLayout
android:id="@+id/balloon_inner_layout"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:layout_gravity="center_vertical">
<ImageView
android:id="@+id/image"
android:layout_width="50dip"
android:layout_height="50dip"
android:contentDescription="@string/descr_image"
android:src="@drawable/stub"
android:scaleType="centerCrop"
android:layout_gravity="center_vertical"/>
<LinearLayout
android:paddingLeft="5dip"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical">
<TextView
android:id="@+id/price"
android:textStyle="bold"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
<TextView
android:id="@+id/address"
android:textStyle="bold"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
<TextView
android:id="@+id/sup"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:visibility="gone"/>
<TextView
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:id="@+id/rooms"
android:visibility="gone"/>
</LinearLayout>
</LinearLayout>
在我的MapActivity类中,我实现了OnAnnotationSelectionChangedListener。 别忘了设置监听器。
在MapActivity#onAnnotationSelected中,我将收到的注释转换为我的CustomAnnotation,这样我就可以使用其他字段,将布局扩展到View对象,并将setText扩展到我的所有TextViews:
@Override
public void onAnnotationSelected(PolarisMapView mapView,
MapCalloutView calloutView, int position, Annotation annotation) {
CustomAnnotation ca = (CustomAnnotation) annotations.get(position);
View view = (View)getLayoutInflater().inflate(R.layout.balloon_test, null);
CustomObject object = ca.getCustomObject();
TextView txView = (TextView)view.findViewById(R.id.field1);
txView.setText(object.getField1());
txView.setVisibility(View.VISIBLE);
...
//set aditional data in your callout
...
calloutView.setDisclosureEnabled(true);
calloutView.setClickable(true);
calloutView.setCustomView(view);
calloutView.show(mPolarisMapView, annotation.getPoint(), false);
}
这就是全部。 希望它对某人有所帮助。