Mapx开发目标轨迹显示核心代码(VC++)

本文详细介绍了如何在地图控件中创建并管理目标轨迹层,包括变量声明、地图控件创建、目标轨迹层创建、比例尺图层响应、目标位置更新及轨迹绘制等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、申明变量
 CMapX              m_ctrlMapX;
 CMapXLayer     m_objLayer;            //运动目标图层
 CMapXLayer     m_traceLayer;          //目标轨迹层
  CMapXLayer    m_scaleBarLayer;   //比例尺图层
 CMapXFeature  m_objFt;
 double                m_lfCenterLon;       //地图中心经度
 double                m_lfCenterLat;         //地图中心纬度
 CMapXFeature m_objTrackFt[MAXNUMINEMAP];
二、 创建地图控件
 CRect rc;
 GetClientRect(&rc);
 m_ctrlMapX.Create(NULL,WS_VISIBLE, rc, this, IDC_MAP);
 m_ctrlMapX.SetCurrentTool(miPanTool);
 char GEOName[MAX_PATH];
 GetCurrentDirectory(MAX_PATH,GEOName);
 strcat(GEOName,"/map/asia.gst"); 字串3
 
 m_ctrlMapX.SetGeoSet(GEOName);//设置地图名字
 m_ctrlMapX.SetTitleText("");
 m_ctrlMapX.SetMapUnit(miUnitKilometer);//设置地图单位
 m_ctrlMapX.SetPaperUnit(miPaperUnitKilometer);
 m_scaleBarLayer = m_ctrlMapX.GetLayers().AddUserDrawLayer("比例尺", 1);//添加用户显示图层
 m_ctrlMapX.SetAutoRedraw(TRUE);
三、创建目标轨迹层
 m_objLayer = m_ctrlMapX.GetLayers().CreateLayer("目标",NULL, 1, 32);
 m_ctrlMapX.GetLayers().SetAnimationLayer(m_objLayer);//设置该层为动画图层
 m_objLayer.SetSelectable(FALSE);//设置该层目标为不可选择
 m_objLayer.SetAutoLabel(TRUE);//设置该层目标为自动标注
 m_objLayer.GetLabel().SetLineType(miLineTypeNone);//设置标注线形
 m_objLayer.GetLabel().SetPosition(miPositionTR);//设置标注位置
 m_objLayer.GetLabel().SetOffset(2);//设置标注偏移量
 m_objLayer.SetOverrideStyle(TRUE);//该层中所有Feature使用相同的style,***关键点,使用不同的style时,参数为FALSE*** 字串1
 m_objLayer.GetLabel().GetStyle().SetTextFontColor(miColorRed);//设置标注颜色
 m_objLayer.GetLabel().SetOverlap(TRUE);//允许标注覆盖
 m_objLayer.GetStyle().GetSymbolFont().SetName("Mapinfo Symbols");//设置符号feature使用的字体
 m_objLayer.GetStyle().SetSymbolCharacter(53);//设置符号feature使用的字符
 m_objLayer.GetStyle().SetSymbolFontColor(RGB(255,0,0));//设置符号feature使用的颜色
 m_objLayer.GetStyle().SetLineWidth(1);//设置线形feature的线宽
 m_objLayer.SetDrawLabelsAfter(TRUE);//在所有图层绘制完后再绘制标注
四、 创建目标轨迹层
 m_traceLayer = m_ctrlMapX.GetLayers().CreateLayer("轨迹",NULL, 2, 32);
 m_ctrlMapX.GetLayers().SetAnimationLayer(m_traceLayer);
 m_traceLayer.SetSelectable(FALSE);
 m_traceLayer.SetDrawLabelsAfter(TRUE);//影响标注刷新的关键
 
 
五、 响应OnDrawUserLayer绘制比例尺图层
 
 
六、 定时器中改变目标位置
 
 
七、 刷新电子地图
 m_objLayer.BeginAccess(miAccessReadWrite);//大大减少CPU开销
 m_traceLayer.BeginAccess(miAccessReadWrite);//大大减少CPU开销
 for(int i=0;i<MAXNUMINEMAP; i++)
 {
  //设定目标位置
  sObjectInEMap[i].ft.GetPoint().Set(sGISPoint[i][0].x, sGISPoint[i][0].y);
  sObjectInEMap[i].ft.Update();
 
 
  //设置目标轨迹
  //为空的时候创建目标轨迹对象
  if (m_objTrackFt[i]==NULL)
  {
   CMapXFeature ft;
   ft.CreateDispatch(ft.GetClsid());
   ft.Attach(m_ctrlMapX.GetDispatch(FALSE));
   ft.SetType(miFeatureTypeLine);
   ft.GetStyle().SetLineColor(colors[i%12]);
   ft.GetStyle().SetLineStyle(1);//77-铁轨(参考帮助)
   ft.GetStyle().SetLineWidth(2);
   CMapXPoints pts;
   pts.CreateDispatch(pts.GetClsid());
   //加入坐标数据
   pts.AddXY(sGISPoint[i][1].x, sGISPoint[i][1].y);
   pts.AddXY(sGISPoint[i][0].x, sGISPoint[i][0].y);
   ft.GetParts().Add(pts);
   //加入到目标图层
   m_objTrackFt[i] = m_traceLayer.AddFeature((LPDISPATCH)ft); 字串6
  }
  else
  {
   //更新目标轨迹对象
   m_objTrackFt[i].GetParts().Item(1).AddXY(sGISPoint[i][0].x, sGISPoint[i][0].y);
   m_objTrackFt[i].Update();
  }
  sGISPoint[i][1] = sGISPoint[i][0];
 }
 m_traceLayer.EndAccess();
 m_objLayer.EndAccess();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值