实现shape图层添加label

void CmapwingisTest2View::OnToolsAdd32780()

{

         TCHAR szFilters[]= _T("SHP Files (*.shp)|*.shp||");  

 

 

         CFileDialog fileDlg (TRUE,_T("shp"),_T("*.shp"),  

                   OFN_FILEMUSTEXIST| OFN_HIDEREADONLY, szFilters, this);  

 

         if( fileDlg.DoModal ()!=IDOK )   return;

         CString m_strFilePath = fileDlg.GetPathName();  

 

 

         if (_T("")!=m_strFilePath)  

         {  

 

                   // 先删除所有图层  

                   //m_map.RemoveAllLayers();  

 

                   // 获取后缀名判断文件是tif图像还是shp文件  

                   CString strExt = m_strFilePath.Right(3);  

                    

                   if (_T("shp")==strExt)  

                   {  

                            mapWindow::IShapefilePtr pshapefilebound;

                            pshapefilebound.CreateInstance(__uuidof(mapWindow::Shapefile));

                            pshapefilebound->Open(_bstr_t(m_strFilePath),false );

                            m_map.AddLayer( pshapefilebound,TRUE) ;

                            mapWindow::ILabelsPtr labels=pshapefilebound->GetLabels( );//?

                            labels->PutFontSize(12);

                            labels->PutFontBold(true);

                            labels->PutFontOutlineVisible(true);

                            labels->PutFontOutlineWidth(4);

                            mapWindow::ILabelCategoryPtr cat;

                            labels->AddCategory("Red");

 

 

                            long fieldIndex = 1;//默认首个列

                            CString str;

                            IFieldPtr Fields;

                            //pshapefilebound->GetField(0);

                            _variant_t var;

                            for (long i = 0; i < pshapefilebound->GetNumShapes() ; i++)

                            {

                                     IShapePtr shp =  pshapefilebound->GetShape(i);

                                     IPointPtr pt= shp->GetCenter(   );

                                     var = pshapefilebound->GetCellValue(fieldIndex, i);

                                     str = var.bstrVal; //需要判断本列是否为文本,待解决

                                     labels->AddLabel( _bstr_t(str ),pt->Getx(),pt->Gety(),0,laCenter);

                            }

                            labels->put_Synchronized(true);

  

 

posted on 2019-09-09 14:14  激流勇进1  阅读(365)  评论(0编辑  收藏  举报