gdal笔记


---------安装gdal

http://wiki.woodpecker.org.cn/moin/lilin/gdal-introduce#head-ddf209b471ede52abec271c974ff6e89c5daed49-----安装指南

https://pypi.python.org/pypi/GDAL/1.10.0------下载地址

:安装python版的gdal。因为官方打包的少了一个“cpl_port.h”和cpl_port.h中include ***等其它相关的头文件,还少了“gdal_i.lib”和“gdal110.dll”文件。

所以安装的时候需要先安装C++版,等安装完之后将C++打完包的目录“C:\warmerda\bld”下拷贝所需要的文件,然后复制到相对应的地方即可。

步骤如下:

注意:最好将C++版和PYTHON版的gdal的版本都下载一致,我这里使用的是GDAL的1.10.0版本。

1:先安装C++版的gdal。生成安装文件C:\warmerda。--------下载

地址“http://wiki.woodpecker.org.cn/moin/lilin/gdal-introduce#head-ddf209b471ede52abec271c974ff6e89c5daed49”

2:下载python版gdal。然后解压到“C:\Users\hongliang.lu\Desktop”。------下载地址https://pypi.python.org/pypi/GDAL/1.10.0

3:将“C:\warmerda\bld\include”下的所有文件拷贝复制到“C:\Users\hongliang.lu\Desktop\GDAL-1.10.0\GDAL-1.10.0\extensions”下;

4:将“C:\warmerda\bld\lib”下的所有文件拷贝复制到"C:\Users\hongliang.lu\Desktop\GDAL-1.10.0\GDAL-1.10.0"下;

5:cmd==>cd 到C:\Users\hongliang.lu\Desktop\GDAL-1.10.0\GDAL-1.10.0,然后键入命令"python setup.py install",

然后会在python的安装目录"C:\python275\Lib\site-packages"生成GDAL-1.10.0-py2.7-win32.egg文件夹(注意是文件夹不是文件)。

6:因为如果使用ipython导入import gdal的时候需要gdal的dll文件,所以需要将c++安装好的包的dll拷贝到python的根目录下。即

“C:\warmerda\bld\bin\gdal110.dll”拷贝到“C:\python275”下。


-------------geos编译安装
http://www.kaiyuanba.cn/html/1/131/227/8010.htm


编译64位的gdal版本gdal-1.11.1,geos注意:

注意点,

打开 vistual studio cross tools command prompt (2010)
如果没有使用这个编译器:则会报错:
LINK : fatal error LNK1123: failure during conversion to COFF: file invalid or corrupt
NMAKE : fatal error U1077: '"C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\BIN\amd64\link.EXE"' : return code '0x463'
Stop.


gdal笔记_第1张图片
修改gdal源码下nmake.opt文件:
......
WIN64=YES
......
# Uncomment for GEOS support (GEOS >= 3.1.0 required)
GEOS_DIR=D:/tetetst/geos-3.4.2
GEOS_CFLAGS = -I$(GEOS_DIR)/capi -I$(GEOS_DIR)/include -DHAVE_GEOS
GEOS_LIB     = $(GEOS_DIR)/src/geos_c_i.lib

然后运行下面的命令:
nmake /f makefile.vc
nmake /f makefile.vc install
nmake /f makefile.vc devinstall
最后再C:\warmerda\bld即可看到生成的库。
运行gdal源码中的makegdal_gen.bat工具,可以生成sln工程,也可以直接使用这个sln使用vs2010打开编译。




----------gdal,ogr教程

http://www.gdal.org/ogr/ogr_apitut.html


---------------------C++操作OGR

http://blog.csdn.net/tszhangjunqiao/article/details/16859553


----------求某一个车道标记点pLaneMark  lanemark  在道路pRoad  road的左侧还是右侧:

1:先求得pLaneMark距离pRoad上所有Point最近的点PointB。

2:将在pRoad上求得的PointB点所在的索引上加一,求取pRoad上PointB的下一个点PointC。

3:然后使用矢量算法,对pLaneMark,PointB,PointC这三个点求顺时针或者逆时针,即可得知pLaneMark在pRoad的左侧还是右侧。

[plain]  view plain copy 在CODE上查看代码片
  1. 判断 某一点在直线左右侧 方法判断 某一点在直线左右侧   
  2. 左右方向是相对前进方向的,只要指定了前进方向就可以知道左右(比如指定前进方向是从直线的起点到终点).判断点在直线的左侧还是右侧是计算几何里面的一个最基本算法.使用矢量来判断.   
  3. 定义:平面上的三点P1(x1,y1),P2(x2,y2),P3(x3,y3)的面积量:  
  4. S(P1,P2,P3)=|y1 y2 y3|= (x1-x3)*(y2-y3)-(y1-y3)(x2-x3)   
  5. 当P1P2P3逆时针时S为正的,当P1P2P3顺时针时S为负的。   
  6. 令矢量的起点为A,终点为B,判断的点为C,   
  7. 如果S(A,B,C)为正数,则C在矢量AB的左侧;   
  8. 如果S(A,B,C)为负数,则C在矢量AB的右侧;   
  9. 如果S(A,B,C)为0,则C在直线AB上。  

判断方法2:

[cpp]  view plain copy
  1. void DecomposeOGRGeometry(OGRGeometry * pGeometry,   
  2.                           vector & vtPoint,   
  3.                           vector & vtLineString,   
  4.                           vector & vtPolygon)  
  5. {  
  6.     if(!pGeometry)  
  7.     {  
  8.         return ;  
  9.     }  
  10.       
  11.     int i=0;  
  12.     OGRwkbGeometryType geometryType = pGeometry->getGeometryType();  
  13.     switch (geometryType)  
  14.     {  
  15.     case wkbGeometryCollection:  
  16.         {  
  17.             /// 遍历每一个Geometry  
  18.             OGRGeometryCollection * pGeometryCollection = (OGRGeometryCollection *)pGeometry;  
  19.             for (i = 0; pGeometryCollection->getNumGeometries() > i; ++i)  
  20.             {  
  21.                 OGRGeometry * pGeo = pGeometryCollection->getGeometryRef(i);  
  22.                 DecomposeOGRGeometry(pGeo, vtPoint, vtLineString, vtPolygon);  
  23.             }  
  24.         }  
  25.         break;  
  26.     case wkbMultiLineString:  
  27.         {  
  28.             /// 遍历每一个LineString  
  29.             OGRMultiLineString * pMultiLineString = (OGRMultiLineString *)pGeometry;  
  30.             for (i = 0; pMultiLineString->getNumGeometries() > i; ++i)  
  31.             {  
  32.                 OGRGeometry * pGeo = pMultiLineString->getGeometryRef(i);  
  33.                 vtLineString.push_back((OGRLineString *)pGeo);  
  34.             }  
  35.         }  
  36.         break;  
  37.     case wkbLineString:  
  38.         {  
  39.             vtLineString.push_back((OGRLineString *)pGeometry);  
  40.         }  
  41.         break;  
  42.     case wkbMultiPoint:  
  43.         {  
  44.             /// 遍历每一个Point  
  45.             OGRMultiPoint * pMultiPoint = (OGRMultiPoint *)pGeometry;  
  46.             for (i = 0; pMultiPoint->getNumGeometries() > i; ++i)  
  47.             {  
  48.                 OGRGeometry * pGeo = pMultiPoint->getGeometryRef(i);  
  49.                 vtPoint.push_back((OGRPoint *)pGeo);  
  50.             }  
  51.         }  
  52.         break;  
  53.     case wkbPoint:  
  54.         {  
  55.             vtPoint.push_back((OGRPoint *)pGeometry);  
  56.         }  
  57.         break;  
  58.     case wkbMultiPolygon:  
  59.         {  
  60.             /// 遍历每一个Polygon  
  61.             OGRMultiPolygon * pMultiPolygon = (OGRMultiPolygon *)pGeometry;  
  62.             for (i = 0; pMultiPolygon->getNumGeometries() > i; ++i)  
  63.             {  
  64.                 OGRGeometry * pGeo = pMultiPolygon->getGeometryRef(i);  
  65.                 vtPolygon.push_back((OGRPolygon *)pGeo);  
  66.             }  
  67.         }  
  68.         break;  
  69.     case wkbPolygon:  
  70.         {  
  71.             vtPolygon.push_back((OGRPolygon *)pGeometry);  
  72.         }  
  73.         break;  
  74.     default:  
  75.         {  
  76.             break;  
  77.         }  
  78.     }  
  79.       
  80.     return ;  
  81. }  

[cpp]  view plain copy
  1. //判断point1和point2是否在道路的同一侧  
  2. bool CRoad::IsOnSameSide(OGRPoint *point1, OGRPoint *point2)  
  3. {  
  4.     bool bEnable= false;  
  5.     OGRLineString lineString;  
  6.     lineString.addPoint(point1);  
  7.     lineString.addPoint(point2);  
  8.     OGRGeometry *pRoadGeo = this->GetGeometry();  
  9.     //获取相交  
  10.     OGRGeometry * pInterGeo = lineString.Intersection(pRoadGeo);  
  11.     if(pInterGeo)  
  12.     {  
  13.         vector vtPoint;  
  14.         vector vtLineString;  
  15.         vector vtPolygon;     
  16.         DecomposeOGRGeometry(pInterGeo, vtPoint, vtLineString, vtPolygon );  
  17.         if ((vtPoint.size()%2)==0)//如果相交点的数量为偶数,则在同一侧,否则不在同一侧  
  18.             bEnable= true;  
  19.         else  
  20.             bEnable= false;  
  21.     }  
  22.     else  
  23.     {  
  24.         bEnable=true;  
  25.     }  
  26.     return bEnable;  
  27. }  


---------在使用OGRGeometry::Intersects的时候会出现失败的情况,这可能是因为在编译gdal的时候只编译的ogr库,没有编译geos库导致的。

可以参开如下官网的描述:


[cpp]  view plain copy
  1. OGRBoolean OGRGeometry::Intersects  (   OGRGeometry *   poOtherGeom  )   const [virtual]  
  2. Do these features intersect?  
  3.   
  4. Determines whether two geometries intersect. If GEOS is enabled, then this is done in rigerous fashion otherwise TRUE is returned if the envelopes (bounding boxes) of the two features overlap.  
  5.   
  6. The poOtherGeom argument may be safely NULL, but in this case the method will always return TRUE. That is, a NULL geometry is treated as being everywhere.  
  7.   
  8. This method is the same as the C function OGR_G_Intersects().  
  9.   
  10. Parameters:  
  11. poOtherGeom     the other geometry to test against.  
  12. Returns:  
  13. TRUE if the geometries intersect, otherwise FALSE.  
  14. References getEnvelope().  


---------------------计算两个向量的角度


将(x3,y3)和(x2,y2)移动距离x防线x3-x0,y方向y3-y0的距离。

[cpp]  view plain copy
  1. //移动pObject中所有形状点x-->dScaleMove_X,y-->dScaleMove_Y  
  2. void MoveLineString(SHPObject * const pObject, double dScaleMove_X, double dScaleMove_Y)  
  3. {  
  4.     int VerticesCnt= pObject->nVertices;  
  5.     for (int i = 0; i < VerticesCnt; ++i)  
  6.     {  
  7.         double & dx= pObject->padfX[i];  
  8.         double & dy= pObject->padfY[i];  
  9.         dx= dx- dScaleMove_X;  
  10.         dy= dy- dScaleMove_Y;  
  11.     }  
  12. }  
  13.   
  14. double GetDistince(double dx1, double dy1, double dx2, double dy2)  
  15. {  
  16.     double dDistince= sqrt( pow(dx1-dx2, 2)+ pow(dy1-dy2, 2)  );  
  17.     return dDistince;  
  18. }  
  19.   
  20. /*计算两个有向线段的夹角,其两条线段分别为: 
  21. (x0,y0)-->(x1,y1) 
  22. (x0,y0)-->(x2,y2) 
  23. 其(x0,y0)为其交点 
  24. */  
  25. double GetThreePointsAngle(double x1, double y1, double x0, double y0, double x2, double y2)  
  26. {  
  27.     //平面距离  
  28.     double a = GetDistince(x1, y1, x0, y0);  
  29.     double b = GetDistince(x2, y2, x0, y0);  
  30.     double c = GetDistince(x1, y1, x2, y2);  
  31.   
  32.     double fHuDu = acos((a*a + b*b - c*c) / (2.0*a*b));  
  33.   
  34.     double dJiaoDu= fHuDu*180/PI;  
  35.     return dJiaoDu;//fAngle>0 ? fAngle : PI;  
  36. }  

使用:

[cpp]  view plain copy
  1. 获取向量pstFristSlope-->pstFinalSlope和  
  2. 向量pstRoad->iFnode-->pstRoad->iTnode  
  3. 之间的夹角*/  
  4. _MdbSlope_* pstFristSlope = vecMdbSlope[0];  
  5. _MdbSlope_* pstFinalSlope = vecMdbSlope[nSlopeCnt-1];  
  6.   
  7.   
  8. double pdlX[2];  
  9. double pdlY[2];  
  10. double pdlZ[2];  
  11. pdlX[0] = pstFristSlope->stNode.X;  
  12. pdlY[0] = pstFristSlope->stNode.Y;  
  13. pdlZ[0] = 0.0;  
  14. pdlX[1] = pstFinalSlope->stNode.X;  
  15. pdlY[1] = pstFinalSlope->stNode.Y;  
  16. pdlZ[1] = 0.0;  
  17. SHPObject* pObject = SHPCreateSimpleObject(SHPT_ARC, 2, pdlX, pdlY, pdlZ);  
  18.   
  19.   
  20. double dScaleMove_X= pstFristSlope->stNode.X- pstNode->dx;  
  21. double dScaleMove_Y= pstFristSlope->stNode.Y- pstNode->dy;  
  22.   
  23.   
  24. //移动pstFristSlope-->pstFinalSlope坐标到pstRoad->iFnode,  
  25. //相应的pstFinalSlope点也会移动  
  26. MoveLineString(pObject, dScaleMove_X, dScaleMove_Y);  
  27.   
  28.   
  29. // double x1= pObject->padfX[0];  
  30. // double y1=pObject->padfY[0];  
  31. double x1=pstRoad->TnodeCoord.X;  
  32. double y1=pstRoad->TnodeCoord.Y;  
  33. double x2=pObject->padfX[1];  
  34. double y2=pObject->padfY[1];  
  35. SHPDestroyObject(pObject);  
  36.   
  37.   
  38. double x0= pstRoad->FnodeCoord.X;  
  39. double y0= pstRoad->FnodeCoord.Y;  
  40.   
  41.   
  42. double dJiaoDu= GetThreePointsAngle(x1, y1, x0, y0, x2, y2);  





你可能感兴趣的:(gdal笔记)