亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? esrishapefile.cs

?? 開源用于shp文件的讀取操作
?? CS
?? 第 1 頁 / 共 2 頁
字號:
using System;
using System.Collections.Generic;
using System.Text;
using System.IO;


using System.Data.Odbc;  //add by hand,which is needed when load the layer attribute information
using System.Data.OleDb;
using System.Collections;
using System.Data;
using System.Xml;


namespace CGCL.CGFiles
{
    public class CGShapeFileParser
    {
        public class ESRI_ShxHeader
        {
            int FileCode; //9994
            int[] Unused2 = new int[5];
            int FileLength;
            int Version; //1000
            int ShapeType; // 0- Null shape
            // 1- Point
            // 3-Arc
            // 5-Polygon
            // 8-MultiPoint
            double XMin;
            double YMin;
            double XMax;
            double YMax;
            int[] Unused3 = new int[8];
        }

        class ESRI_ShapeFile
        {
            int FileCode; //9994
            int[] Unused = new int[5];
            int FileLength;
            int Version; //1000
            int ShapeType; // 0- Null shape
            // 1- Point
            // 3-Arc
            // 5-Polygon
            // 8-MultiPoint
            double XMin;
            double YMin;
            double XMax;
            double YMax;
            int[] Unused1 = new int[8];
        }


        class ESRI_RecordHeader
        {
            int RecNumber;
            int ContentLength;
        }

        class ESRI_PointContent
        {
            int ShapeType;
            double X;
            double Y;
        }
        class ESRI_IndexRec//索引文件
        {
            int Offset;
            int ContentLen;
        }

        class ESRI_ArcContent
        {
            int ShapeType;
            double xmin;
            double ymin;
            double xmax;
            double ymax;
            int NumParts;
            int NumPoints;
        }

        class ESRI_PolygonContent
        {
            int ShapeType;
            double xmin;
            double ymin;
            double xmax;
            double ymax;
            int NumParts;
            int NumPoints;
        }     
               
        public bool LoadShapeFile(CGDataAdapter.CGLocalGeoDataAdapter adapter)
        {

            string connectionString;
            OdbcConnection connection;
            OdbcDataAdapter OdbcAdapter;


            CGMap.CGGeoLayer geolayer = adapter.getMasterGeoLayer();            

            string shpfilepath = adapter.getPath();
            string shpfilename = adapter.getFileName();
            string shxfilepath = shpfilepath.Substring(0, shpfilepath.LastIndexOf("\\") + 1) + adapter.getFileName() + ".shx";

            //read out the layer attribute infomation
            connectionString = "Dsn=Visual FoxPro Database;sourcedb=" + shpfilepath + ";sourcetype=DBF;exclusive=No;backgroundfetch=Yes;collate=Machine";
            connection = new OdbcConnection(connectionString);
            connection.Open();
            OdbcAdapter = new OdbcDataAdapter("select * from " + shpfilename, connectionString);

            // Create new DataTable and DataSource objects.
            DataSet ds = new DataSet();
            OdbcAdapter.Fill(ds);
            connection.Close();

            if (geolayer == null) return false;

            try
            {
                //先讀取.shx文件,得到文件的總字節長度
                FileStream fs = new FileStream(shxfilepath, FileMode.Open, FileAccess.Read);   //文件流形式  
                BinaryReader BinaryFile = new BinaryReader(fs);  //二進制讀取文件的對象
                long BytesSum = fs.Length;  //得到文件的字節總長  
                int shapecount = (int)(BytesSum - 100) / 8;  //得以總記錄數目             

                BinaryFile.Close();
                fs.Close();

                //打開shp文件
                if (shxfilepath == "")
                {
                    //  MessageBox.Show("索引文件打開出錯");
                    return false;
                }
                //打開.shp文件,讀取x,y坐標的信息
                fs = new FileStream(shpfilepath, FileMode.Open, FileAccess.Read);   //文件流形式
                BinaryFile = new BinaryReader(fs);     //打開二進制文件   

                BinaryFile.ReadBytes(32);  //先讀出36個字節,緊接著是Box邊界合
                int shapetype = BinaryFile.ReadInt32();              
                
                geolayer.envlope.left = BinaryFile.ReadDouble();   //讀出整個shp圖層的邊界合
                geolayer.envlope.bottom = BinaryFile.ReadDouble();
                geolayer.envlope.right = BinaryFile.ReadDouble();
                geolayer.envlope.top = BinaryFile.ReadDouble();


                BinaryFile.ReadBytes(32);  //   shp中尚未使用的邊界盒    


                //Get Shape Data From Here On
                int stype;
                double x, y;
                double left, right, top, bottom;

                int partcount;
                int pointcount;

                switch (shapetype)
                {
                    case 1://single point

                                geolayer.shapeType = CGConstants.CGShapeType.SHAPE_POINT;
                                for (int i = 0; i < shapecount; i++)
                                {
                                    CGGeoShape.CGGeoPoint gps = new CGGeoShape.CGGeoPoint();

                                    BinaryFile.ReadBytes(12); //記錄頭8個字節和一個int(4個字節)的shapetype

                                   /* stype = BinaryFile.ReadInt32();
                                  
                                    if (stype != shapetype)
                                        continue;

                                    */
                                    x = BinaryFile.ReadDouble();
                                    y = BinaryFile.ReadDouble();

                                    gps.objectID = i;
                                    gps.objectUID = i;

                                    gps.x = x;
                                    gps.y = y;
                                    gps.z = 0;
                                    gps.envlope.left = gps.x;
                                    gps.envlope.right = gps.x;
                                    gps.envlope.top = gps.y;
                                    gps.envlope.bottom = gps.y;
                                    geolayer.getDataContainer().Add(gps);
                                }
                        break;

                    case 8://multi points layer
                        break;

                    case 3://Polyline layer
                        geolayer.shapeType = CGConstants.CGShapeType.SHAPE_LINE;

                        for (int i = 0; i < shapecount; i++)
                        {
                            geolayer.getAttributeContainer().Add(ds.Tables[0].Rows[i][0]);      //read out the attribute step by step

                            BinaryFile.ReadBytes(12);

                            //	 int pos = indexRecs[i].Offset+8;
                            //	 bb0.position(pos);
                            //	 stype = bb0.getInt();
                            //	 if (stype!=nshapetype){
                            //		 continue;
                            //	 }

                            left = BinaryFile.ReadDouble();
                            bottom = BinaryFile.ReadDouble();
                            right = BinaryFile.ReadDouble();
                            top = BinaryFile.ReadDouble();

                            partcount = BinaryFile.ReadInt32();
                            pointcount = BinaryFile.ReadInt32();

                            int[] parts = new int[partcount];
                            int[] partspos = new int[partcount];

                            double[] xpoints = new double[pointcount];
                            double[] ypoints = new double[pointcount];
                            double[] zpoints = new double[pointcount];

                            //firstly read out parts begin pos in file
                            for (int j = 0; j < partcount; j++)
                            {
                                parts[j] = BinaryFile.ReadInt32();
                            }
                            //shift them to be points count included in parts
                            if (partcount > 0)
                                partspos[0] = 0;

                            int newpos = 0;
                            for (int j = 0; j <= partcount - 2; j++)
                            {
                                parts[j] = parts[j + 1] - parts[j];
                                newpos += parts[j];
                                partspos[j + 1] = newpos;
                            }

                            parts[partcount - 1] = pointcount - parts[partcount - 1];

                            //read out coordinates
                            for (int j = 0; j < pointcount; j++)
                            {
                                x = BinaryFile.ReadDouble();
                                y = BinaryFile.ReadDouble();
                                xpoints[j] = x;
                                ypoints[j] = y;
                                zpoints[j] = 0;
                            }
                            if (pointcount > 1)
                            {
                                CGGeoShape.CGGeoLine gl = new CGGeoShape.CGGeoLine(xpoints, ypoints, zpoints, parts, partspos, pointcount, partcount);
                                gl.envlope.left = left;
                                gl.envlope.right = right;
                                gl.envlope.top = top;
                                gl.envlope.bottom = bottom;

                                gl.objectID = i;
                                gl.objectUID = i;
                                geolayer.getDataContainer().Add(gl);

                            }
                        }
                        break;
                    case 5://Polygon layer
                        geolayer.shapeType = CGConstants.CGShapeType.SHAPE_POLYGON;
                        for (int i = 0; i < shapecount; i++)
                        {
                            geolayer.getAttributeContainer().Add(ds.Tables[0].Rows[i][0]);   

                          /*  bb0.rewind();
                            bb0.position(indexRecs[i].Offset + 8);
                            stype = BinaryFile.ReadInt32();

                            if (stype != shapetype)
                            {
                                continue;
                            }*/

                            BinaryFile.ReadBytes(12);

                            left = BinaryFile.ReadDouble();
                            bottom = BinaryFile.ReadDouble();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产激情视频一区二区在线观看 | 国产原创一区二区| 国产麻豆9l精品三级站| av激情综合网| 欧美精品乱码久久久久久| 欧美白人最猛性xxxxx69交| 日韩三级视频在线观看| 中文字幕欧美日韩一区| 亚洲狠狠丁香婷婷综合久久久| 免费观看日韩电影| 94色蜜桃网一区二区三区| 在线播放国产精品二区一二区四区| 久久综合资源网| 成人欧美一区二区三区黑人麻豆 | 久久精子c满五个校花| 中文字幕一区二区5566日韩| 日本中文一区二区三区| 成人国产精品视频| 日韩欧美国产三级电影视频| 亚洲欧美另类图片小说| 国精产品一区一区三区mba桃花| 欧美午夜一区二区三区免费大片| 国产欧美va欧美不卡在线| 午夜日韩在线观看| 在线观看国产一区二区| 日韩一区二区三区观看| 亚洲综合精品自拍| 不卡一区二区在线| 久久精品水蜜桃av综合天堂| 日韩av电影天堂| 风间由美一区二区av101 | 97久久人人超碰| 久久精品水蜜桃av综合天堂| 蓝色福利精品导航| 欧美精品乱码久久久久久按摩| 中文字幕一区二区三区在线观看 | 国产精品1区二区.| 3d动漫精品啪啪一区二区竹菊 | 日韩欧美激情在线| 日韩成人伦理电影在线观看| 欧美日韩一级二级| 亚洲韩国精品一区| 欧美色区777第一页| 亚洲欧美日韩系列| 色爱区综合激月婷婷| 国产日韩av一区二区| 精品一区二区三区在线播放| 欧美电视剧免费观看| 久久成人免费电影| 日韩一区二区三区精品视频| 日本不卡中文字幕| 日韩一卡二卡三卡四卡| 日韩av在线播放中文字幕| 91国产精品成人| 亚洲综合色丁香婷婷六月图片| 99精品国产热久久91蜜凸| 亚洲欧美aⅴ...| 欧美影视一区在线| 香蕉久久一区二区不卡无毒影院 | 波多野结衣在线aⅴ中文字幕不卡| 欧美夫妻性生活| 青娱乐精品在线视频| 精品久久人人做人人爽| 国产91高潮流白浆在线麻豆| 国产精品网站在线| 色欧美日韩亚洲| 天天色综合天天| 26uuu国产日韩综合| 国产91色综合久久免费分享| 国产精品丝袜久久久久久app| www.一区二区| 亚洲成人一二三| 欧美日韩国产三级| 在线亚洲高清视频| 蜜臀av性久久久久蜜臀aⅴ流畅| 日韩欧美高清在线| 成人影视亚洲图片在线| 亚洲午夜私人影院| 久久婷婷国产综合国色天香| 成人福利视频在线看| 亚洲成av人片在线| 中文字幕av资源一区| 欧美性感一区二区三区| 国产一区二区三区免费观看| 亚洲成a天堂v人片| 亚洲欧洲精品一区二区精品久久久| 日韩亚洲电影在线| 欧美日韩精品欧美日韩精品一| 成人毛片视频在线观看| 极品少妇一区二区| 蜜臀精品一区二区三区在线观看| 亚洲欧美激情插| 日本一区二区三区四区 | 老司机免费视频一区二区三区| 亚洲伊人伊色伊影伊综合网| 国产精品卡一卡二卡三| 久久久久久久久久久久久久久99 | 国产91精品在线观看| 另类的小说在线视频另类成人小视频在线 | 美女视频黄a大片欧美| 亚洲欧美日韩人成在线播放| 欧美国产丝袜视频| 久久免费美女视频| 久久网站最新地址| 欧美电视剧免费观看| 欧美一区二区三区四区高清| 欧美性猛交xxxx黑人交| 在线一区二区三区做爰视频网站| 东方aⅴ免费观看久久av| 国产伦精品一区二区三区视频青涩| 日本vs亚洲vs韩国一区三区二区| 午夜精品一区在线观看| 五月婷婷色综合| 亚洲.国产.中文慕字在线| 五月婷婷综合激情| 日本大胆欧美人术艺术动态| 免费观看日韩av| 国产在线一区观看| 国产一区日韩二区欧美三区| 精品中文av资源站在线观看| 国产综合色视频| 国产成人精品免费网站| 高清国产一区二区三区| caoporm超碰国产精品| 成人黄色软件下载| 一本大道久久a久久精二百| 91福利精品第一导航| 欧美电影在线免费观看| 日韩天堂在线观看| 久久精品视频免费观看| 中文字幕欧美一| 亚洲一区二区av电影| 麻豆91在线观看| 成人午夜电影久久影院| 色视频成人在线观看免| 欧美一卡二卡三卡四卡| 国产拍揄自揄精品视频麻豆| 专区另类欧美日韩| 视频一区欧美精品| 国产精品18久久久| 欧美亚洲国产bt| 精品国产乱码久久久久久老虎| 久久精品亚洲麻豆av一区二区| 综合自拍亚洲综合图不卡区| 婷婷综合五月天| 国产乱子伦一区二区三区国色天香| thepron国产精品| 日韩一区二区不卡| 中文字幕一区二区三区在线播放| 夜夜嗨av一区二区三区四季av| 日韩制服丝袜av| 福利电影一区二区| 91.成人天堂一区| 中文在线资源观看网站视频免费不卡| 一区二区高清在线| 国产成人在线视频网址| 欧美日韩一卡二卡三卡 | 日本午夜一本久久久综合| 国产精品一区二区三区四区| 欧美中文字幕一区| 国产清纯在线一区二区www| 亚洲一区二区三区激情| 风间由美性色一区二区三区| 6080国产精品一区二区| 中文字幕日韩一区| 国产一区在线观看麻豆| 欧美麻豆精品久久久久久| 国产精品嫩草影院com| 另类小说综合欧美亚洲| 欧美三级乱人伦电影| 国产精品久久久久久久裸模| 久久99精品国产麻豆婷婷| 欧美视频在线不卡| 亚洲四区在线观看| 国产一区在线观看视频| 日韩一区二区精品葵司在线| 亚洲午夜久久久久久久久电影院 | 欧美色图一区二区三区| 国产精品久久久爽爽爽麻豆色哟哟| 奇米四色…亚洲| 欧美揉bbbbb揉bbbbb| 亚洲男帅同性gay1069| 成人免费精品视频| 国产日韩欧美一区二区三区综合| 奇米精品一区二区三区在线观看一| 日本道色综合久久| 亚洲精品视频一区| 91麻豆精东视频| 亚洲三级在线播放| 91美女视频网站| 亚洲免费三区一区二区| 91在线无精精品入口| 国产精品视频你懂的| 波多野结衣91| 亚洲人成网站在线| 色婷婷av一区二区三区gif| 亚洲精品中文在线观看| 色妞www精品视频| 亚洲综合色在线| 欧美日韩精品一区二区三区蜜桃|