Flex4 动态生成,LineChart,AreaChart,ColumnChart,PieChart,DataGrid等
2011-03-21 14:35
369 查看
package xiaosi.baiduMap;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.os.Bundle;
import com.baidu.mapapi.BMapManager;
import com.baidu.mapapi.GeoPoint;
import com.baidu.mapapi.MKAddrInfo;
import com.baidu.mapapi.MKDrivingRouteResult;
import com.baidu.mapapi.MKPoiInfo;
import com.baidu.mapapi.MKPoiResult;
import com.baidu.mapapi.MKSearch;
import com.baidu.mapapi.MKSearchListener;
import com.baidu.mapapi.MKTransitRouteResult;
import com.baidu.mapapi.MKWalkingRouteResult;
import com.baidu.mapapi.MapActivity;
import com.baidu.mapapi.MapController;
import com.baidu.mapapi.MapView;
import com.baidu.mapapi.PoiOverlay;
public class BaiduMapActivity extends MapActivity
{
/** Called when the activity is first created. */
private BMapManager mapManager = null;
private String key = "1B79478DA01F7800AEA8602517A6D89B38151105";
private MapView mapView = null;
private MKSearch mKSearch;
private MapController mapController = null;
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
mapManager = new BMapManager(getApplication());
mapManager.init(key, null);
super.initMapActivity(mapManager);
mapView = (MapView) findViewById(R.id.mapView);
// 设置启用内置的缩放控件
mapView.setBuiltInZoomControls(true);
// 得到mMapView的控制权,可以用它控制和驱动平移和缩放
mapController = mapView.getController();
// 设置地图zoom级别
mapController.setZoom(12);
mKSearch = new MKSearch();
mKSearch.init(mapManager, new MySearchListener());// 注意,MKSearchListener只支持一个,以最后一次设置为准
//搜索山东科技大学附近(5000)的KTV
if (mKSearch.poiSearchNearBy("KTV", new GeoPoint(
(int) (36.001618315221194 * 1E6),
(int) (120.11934041976929 * 1E6)), 5000) == -1)
{
System.out.println("失败");
}
else
{
System.out.println("成功");
}
}
public class MySearchListener implements MKSearchListener
{
public void onGetAddrResult(MKAddrInfo arg0, int arg1)
{
/*
* 返回地址信息搜索结果。 参数: arg0 - 搜索结果 arg1 - 错误号,0表示结果正确,result中有相关结果信息;100表示结果正确,无相关地址信息
*/
}
public void onGetDrivingRouteResult(MKDrivingRouteResult arg0, int arg1)
{
/*
* 返回驾乘路线搜索结果。 参数: arg0 - 搜索结果 arg1 - 错误号,0表示正确返回
*/
}
public void onGetPoiResult(MKPoiResult arg0, int arg1, int arg2)
{
String result = "";
/*
* 返回poi搜索结果。 参数: arg0 - 搜索结果 arg1 - 返回结果类型: MKSearch.TYPE_POI_LIST MKSearch.TYPE_AREA_POI_LIST MKSearch.TYPE_CITY_LIST arg2 - 错误号,0表示正确返回
*/
if (arg0 == null)
{
return;
}
// 清除地图上已有的所有覆盖物
// mapView.getOverlays().clear();
// PoiOverlay是baidu map api提供的用于显示POI的Overlay
PoiOverlay poioverlay = new PoiOverlay(BaiduMapActivity.this,
mapView);
// 在地图上显示PoiOverlay(将搜索到的兴趣点标注在地图上)
poioverlay.setData(arg0.getAllPoi());
// 为地图添加覆盖物
mapView.getOverlays().add(poioverlay);
//刚开始忘记加这几句代码,地图一直没改变,纠结了很长时间
if (arg0.getNumPois() > 0)
{
// 设置其中一个搜索结果所在地理坐标为地图的中心
MKPoiInfo poiInfo = arg0.getPoi(0);
mapController.setCenter(poiInfo.pt);
}
// 遍历当前页返回的搜索结果(默认只返回10个)
for (MKPoiInfo poiInfo : arg0.getAllPoi())
{
result = result + "\n"+ "名称:" + poiInfo.name + "\n" + "地址:" + poiInfo.address + "\n" + "城市:" + poiInfo.city;
}
//用AlertDialog来显示搜索到的内容
AlertDialog.Builder builder = new AlertDialog.Builder(BaiduMapActivity.this);
builder.setTitle("搜索结果");
builder.setMessage(result);
builder.setPositiveButton("关闭", new android.content.DialogInterface.OnClickListener(){
public void onClick(DialogInterface dialog, int which) {
dialog.dismiss();
}
});
builder.show();
}
public void onGetTransitRouteResult(MKTransitRouteResult arg0, int arg1)
{
/*
* 返回公交搜索结果。 参数: arg0 - 搜索结果 arg1 - 错误号,0表示正确返回, 当返回MKEvent.ERROR_ROUTE_ADDR时,表示起点或终点有歧义, 调用MKTransitRouteResult的getAddrResult方法获取推荐的起点或终点信息
*/
}
public void onGetWalkingRouteResult(MKWalkingRouteResult arg0, int arg1)
{
/*
* 返回步行路线搜索结果。 参数: arg0 - 搜索结果 arg1 - 错误号,0表示正确返回
*/
}
}
@Override
protected boolean isRouteDisplayed()
{
return false;
}
@Override
protected void onDestroy()
{
if (mapManager != null)
{
mapManager.destroy();
mapManager = null;
}
super.onDestroy();
}
@Override
protected void onPause()
{
if (mapManager != null)
{
mapManager.stop();
}
super.onPause();
}
@Override
protected void onResume()
{
if (mapManager != null)
{
mapManager.start();
}
super.onResume();
}
}
相关文章推荐
- FLEX4实践—动态生成DataGrid及自定义itemRenderer
- Silverlight日记:动态生成DataGrid、行列装换、动态加载控件
- 9.动态生成实体类,根据XML模板使用Emit生成动态类绑定到DataGrid
- Silverlight实用窍门系列:10.动态生成DataGrid,动态绑定DataGrid模板列【附带实例源码】
- Flex通过Java读取Excel(详细流程)----Excel在客户端(DataGrid动态根据Excel生成)
- DataGrid连接Access的快速分页法(4)——动态生成SQL语句
- Silverlight动态生成DataGrid的几个方法
- Jquery easyUI datagrid 服务器端动态生成列配置返回到前台显示
- C#实现DataGrid(GridView)动态生成列
- easyui datagrid 动态生成列
- easyui之datagrid:动态生成列(动态报表)
- Flex中如何动态生成DataGrid以及动态生成表头
- Siverlight 动态生成的datagrid改变指定格格内的值
- Siverlight 动态生成datagrid复杂表头
- 10.动态生成DataGrid,动态绑定DataGrid模板列
- Jquery easyUI 创建tab的同时,动态生成datagrid
- 关于动态生成列的DATAGRID不能出发模板列的时间问题
- 动态生成DataGrid的模板列 转帖
- Easyui datagrid+ashx 实现动态生成列
- Silverlight DataGrid 模板列根据内容动态生成控件