我正在mapview上进行多次注释,我正在为右键选择打开一个新的detailWindow。我应该通过标签在detailWindow中显示一些信息,并且要显示的信息对于每个引脚注释是不同的。我怎样才能将一些数据存储到引脚注释中?帮我做这个工作。提前谢谢。
这是我的代码.. 注释创建:
okBtn.addEventListener("click", function(e) {
Ti.API.info("Text = " + textField.value);
mapview.removeAllAnnotations();
Ti.Geolocation.forwardGeocoder(textField.value, function(e) {
var annotations = [];
for(var i = 0; i < 10; i++) {
var pin = Titanium.Map.createAnnotation({
latitude : e.latitude-i,
longitude : e.longitude-i,
animate : true,
pincolor : Titanium.Map.ANNOTATION_RED,
rightButton : Titanium.UI.iPhone.SystemButton.DISCLOSURE//'rightButton.png'
});
annotations[i] = pin;
// suppose mapView is your map object
mapview.addAnnotation(annotations[i]);
}
var region = {
latitude : e.latitude,
longitude : e.longitude,
animate : true,
latitudeDelta : 0.15,
longitudeDelta : 0.15
};
mapview.setLocation(region);
Ti.API.info(e);
});
});
var detailWindow = Ti.UI.createWindow({
backgroundColor : "#fff",
navBarHidden : true,
backgroundImage : 'screen.png'
});
var detailTitle = Ti.UI.createLabel({
color : '#EC6512',
font : {
fontSize : 18,
fontWeight : 'bold',
fontFamily : 'Arial'
},
left : 12,
top : 60,
height : 80,
width : 300,
clickName : 'detailTitle',
});
detailWindow.add(detailTitle);
我应该将文本添加到rightButtonEvent中的detailTitle
标签。
rightButton事件:
mapview.addEventListener('click', function(evt) {
if(evt.clicksource == 'rightButton') {
Titanium.API.info('Right button clicked');
navGroup.open(detailWindow);
};
});
我需要创建一个标签并发送数据以显示在标签中。
答案 0 :(得分:1)
要在引脚中存储数据,您可以在循环中执行此操作,在注释中设置新属性说数据,然后将数据数组设置为: { title, subTitle,...}
for(var i = 0; i < 10; i++)
{
var pin = Titanium.Map.createAnnotation({
latitude : e.latitude-i,
longitude : e.longitude-i,
data:data
animate : true,
pincolor : Titanium.Map.ANNOTATION_RED,
rightButton : Titanium.UI.iPhone.SystemButton.DISCLOSURE//'rightButton.png'
});
annotations[i] = pin;
// suppose mapView is your map object
mapview.addAnnotation(annotations[i]);
}
要在点击事件中访问此数据,同样将其传递到您的窗口:
mapview.addEventListener('click', function(evt) {
if(evt.clicksource == 'rightButton') {
Titanium.API.info('Right button clicked');
var data = evt.annotation.data;
detailWindow.data = data;
navGroup.open(detailWindow);
};
});