private void method_1(ICoLayer icoLayer_1) { for (int i = 0; i < icoLayer_1.Fields.Count; i++) { ICoField field = icoLayer_1.Fields[i]; string name = field.Name; switch (field.Type) { case CoFieldType.整型: ShapeLib.DBFAddField(this.intptr_1, name, ShapeLib.DBFFieldType.FTInteger, 16, 0); this.list_0.Add(name); break; case CoFieldType.浮点型: { int length = field.Length; int precision = field.Precision; ShapeLib.DBFAddField(this.intptr_1, name, ShapeLib.DBFFieldType.FTDouble, length, precision); this.list_0.Add(name); break; } case CoFieldType.字符型: { int num4 = field.Length; ShapeLib.DBFAddField(this.intptr_1, name, ShapeLib.DBFFieldType.FTString, num4, 0); this.list_0.Add(name); break; } case CoFieldType.日期型: ShapeLib.DBFAddField(this.intptr_1, name, ShapeLib.DBFFieldType.FTInteger, 8, 0); this.list_0.Add(name); break; case CoFieldType.二进制: ShapeLib.DBFAddField(this.intptr_1, name, ShapeLib.DBFFieldType.FTLogical, 5, 0); this.list_0.Add(name); break; } } }
public static void CreateShapeFile(string[] args) { string pkValue = string.Empty; bool pkValIsString = false; bool isSdoPoint = false; if (args == null || args.Length < 5) { Console.Write("\nUsage: sdo2shp <username/password>@dbalias> <spatial_table_name> <PK_col> <shape_col> <shapefile> [\"optional_where_clause\"]\n\nPress any key to exit"); Console.ReadLine(); return; } System.Reflection.Assembly assembly = System.Reflection.Assembly.GetExecutingAssembly(); string version = assembly.GetName().Version.ToString(); Console.Write("\nORA2SHP Oracle SDO to Shapefile Utility. Version: " + version + "\n"); Console.Write("====================================================================\n"); string connectionstring = Utils.ParseConnectionString(args[0].ToString()); string where_clause = string.Empty; try { where_clause = args[5].ToString().Trim('"'); } catch (Exception) { } if (where_clause != string.Empty) { if (!where_clause.ToUpper().StartsWith("WHERE")) { where_clause = " where " + where_clause; } } string outShpFile = args[4].ToString(); string tab_name = args[1].ToString(); string pk_column = args[2].ToString(); string sdo_column = args[3].ToString(); if (outShpFile.ToUpper().EndsWith(".SHP")) { outShpFile = outShpFile.Substring(0, outShpFile.Length - 4); } OracleConnection oracon = new OracleConnection(connectionstring); List <GeoInfo> lShpInfo = new List <GeoInfo>(); try { oracon.Open(); string selFirstShp = string.Empty; if (where_clause == string.Empty) { selFirstShp = "select " + args[2].ToString() + "," + args[3].ToString() + " from " + args[1] + " where rownum = 1"; } else { selFirstShp = "select " + pk_column + "," + sdo_column + " from " + tab_name + " " + where_clause + " and rownum = 1"; } try { lShpInfo = getGeomInfo(oracon, selFirstShp, sdo_column); if (lShpInfo.Count == 0) { Console.WriteLine("\nNo rows found it table {0}", args[1]); Console.ReadLine(); oracon.Close(); oracon.Dispose(); return; } } catch (Exception ex) { Console.WriteLine("\nORA2SHP ERROR:\n" + ex.Message + "\n" + ex.StackTrace); } finally { } //Check if its an SDO point geometry GeoInfo geomInfo = lShpInfo[0]; isSdoPoint = isSDOPointType(geomInfo); //Initialize shape type ShapeLib.ShapeType shpType = ShapeLib.ShapeType.Point; try { shpType = GetShapeType(geomInfo); } catch (Exception ex) { Console.Write(ex.Message); Console.ReadLine(); return; } IntPtr hShp = ShapeLib.SHPCreate(outShpFile, shpType); if (hShp.Equals(IntPtr.Zero)) { Console.WriteLine("\nCould not create {0}.shp\nProbable cause: You do not have permissions or file is in use by another process\n\nPress any key to exit", outShpFile); Console.ReadLine(); return; } string sqlselect = string.Empty; if (where_clause == string.Empty) { sqlselect = @"SELECT " + GetColumnNames(oracon, tab_name) + ", " + sdo_column + " from " + tab_name; } else { sqlselect = @"SELECT " + GetColumnNames(oracon, tab_name) + ", " + sdo_column + " from " + tab_name + " " + where_clause; } OracleCommand command1 = oracon.CreateCommand(); command1.CommandText = sqlselect; OracleDataReader dr = command1.ExecuteReader(); int iShape = 0; IntPtr hDbf = IntPtr.Zero; DataTable dt = new DataTable(); System.Collections.Hashtable ht = new System.Collections.Hashtable(); //#if (DEBUG==true) // Console.WriteLine("Before Loop Elapsed Time: " + (DateTime.Now - tstart).ToString()); tstart = DateTime.Now; //#endif #region create dbf // create dbase file hDbf = ShapeLib.DBFCreate(outShpFile); if (!hDbf.Equals(IntPtr.Zero)) { dt = dr.GetSchemaTable(); //Get table metadata dt.Columns.Add("dBaseName"); } int ordinal1 = 0; foreach (DataRow row in dt.Rows) { string name = row["ColumnName"].ToString().ToUpper(); if (name.Length > 10) //Truncate column name to 10 chars { name = name.Substring(0, 10); } int i = 0; while (ht.ContainsKey(name)) //Check if column name exists after truncation { string iVal = (i++).ToString(); if (name.Length + iVal.Length > 10) { name = name.Substring(0, 10 - iVal.Length) + iVal; } else { name = name + iVal; } } ht.Add(name, ordinal1++); row["dBaseName"] = name; string type = row["DataType"].ToString(); switch (type) { case "System.Int32": case "System.Int16": ShapeLib.DBFAddField(hDbf, name, ShapeLib.DBFFieldType.FTInteger, 16, 0); break; case "System.String": int len = Math.Min(255, int.Parse(row["ColumnSize"].ToString())); ShapeLib.DBFAddField(hDbf, name, ShapeLib.DBFFieldType.FTString, len, 0); if (name == args[1].ToString()) { pkValIsString = true; } break; case "System.Boolean": ShapeLib.DBFAddField(hDbf, name, ShapeLib.DBFFieldType.FTLogical, 5, 0); break; case "System.Double": case "System.Float": case "System.Decimal": int prec = int.Parse(row["NumericPrecision"].ToString()); int scale = int.Parse(row["NumericScale"].ToString()); ShapeLib.DBFAddField(hDbf, name, ShapeLib.DBFFieldType.FTDouble, prec, scale); break; case "System.DateTime": ShapeLib.DBFAddField(hDbf, name, ShapeLib.DBFFieldType.FTDate, 8, 0); break; default: ht.Remove(name); row["dBaseName"] = null; ordinal1--; break; } } #endregion create dbf ShapeCreator sc = new ShapeCreator(); IntPtr pShp = new IntPtr(); while (dr.Read()) { //Console.Write("Processing record ..." + iShape.ToString() +"."); pkValue = dr[args[2]].ToString(); OraShape shp = new OraShape(); ShapePartInfo shpInfo = new ShapePartInfo(); try { GeoInfo geoInfo = new GeoInfo(); geoInfo.Geo = (SdoGeometry)dr[sdo_column]; shp = sc.getOraShape(geoInfo, shpType, Convert.ToInt32(dr[pk_column])); } catch (Exception) { continue; } if (!isSdoPoint) { try { shpInfo = sc.getShapePartInfo(geomInfo); } catch (Exception) { continue; } shp.nParts = shpInfo.nParts; shp.PartType = null; shp.PartStarts = shpInfo.PartStarts; if (shp.MList == null || shp.MList.Length == 0) { if (shp.ZList == null || shp.ZList.Length == 0) { pShp = ShapeLib.SHPCreateObject(shpType, -1, shp.nParts, shp.PartStarts, null, shp.nVertices, shp.XList, shp.YList, null, null); } else { pShp = ShapeLib.SHPCreateObject(shpType, -1, shp.nParts, shp.PartStarts, null, shp.nVertices, shp.XList, shp.YList, shp.ZList, null); } } else { pShp = ShapeLib.SHPCreateObject(shpType, -1, shp.nParts, shp.PartStarts, null, shp.nVertices, shp.XList, shp.YList, null, shp.MList); } } else { shp = sc.CreatePointShape(geomInfo, shpType, pkValue); if (shpType == ShapeLib.ShapeType.PointM) { pShp = ShapeLib.SHPCreateObject(shpType, -1, 0, null, null, 1, shp.XList, shp.YList, null, shp.MList); } else if (shpType == ShapeLib.ShapeType.PointZ) { pShp = ShapeLib.SHPCreateObject(shpType, -1, 0, null, null, 1, shp.XList, shp.YList, shp.ZList, null); } else { pShp = ShapeLib.SHPCreateObject(shpType, -1, 0, null, null, 1, shp.XList, shp.YList, null, null); } } try //In case of invalid shapes { ShapeLib.SHPWriteObject(hShp, -1, pShp); } catch (Exception) { Console.WriteLine("Shape with " + args[2].ToString().ToUpper() + "= " + pkValue + " is invalid. Number of vertices: " + shp.nVertices.ToString() + " Number of parts: " + shp.nParts.ToString()); continue; } ShapeLib.SHPDestroyObject(pShp); foreach (DataRow row in dt.Rows) { if (row["dBaseName"] == null || row["dBaseName"].ToString() == string.Empty) { continue; } int ordinal = (int)ht[row["dBaseName"].ToString()]; string fieldName = row["ColumnName"].ToString(); if (dr[fieldName] is DBNull) { continue; } switch (row["DataType"].ToString()) { case "System.Int32": case "System.Int16": ShapeLib.DBFWriteIntegerAttribute(hDbf, iShape, ordinal, int.Parse(dr[fieldName].ToString())); break; case "System.String": ShapeLib.DBFWriteStringAttribute(hDbf, iShape, ordinal, dr[fieldName].ToString()); break; case "System.Boolean": ShapeLib.DBFWriteLogicalAttribute(hDbf, iShape, ordinal, bool.Parse(dr[fieldName].ToString())); break; case "System.Double": case "System.Float": case "System.Decimal": ShapeLib.DBFWriteDoubleAttribute(hDbf, iShape, ordinal, double.Parse(dr[fieldName].ToString())); break; case "System.DateTime": DateTime date = DateTime.Parse(dr[fieldName].ToString()); ShapeLib.DBFWriteDateAttribute(hDbf, iShape, ordinal, date); break; } } iShape++; //dr.NextResult(); } Console.WriteLine("Converted " + iShape.ToString() + " shapes in: " + (DateTime.Now - tstart).ToString()); // free resources ShapeLib.SHPClose(hShp); ShapeLib.DBFClose(hDbf); //Create projection file if needed CreatePrjFile(oracon, args[1].ToString(), args[3].ToString(), outShpFile); //Console.Write("Done.\n"); Console.Write("\nCreated shapefile " + args[4].ToString() + " with " + iShape.ToString() + " records.\nTotal Elapsed Time: " + (DateTime.Now - tProgramstart).ToString() + "\nPress any key to exit."); Console.ReadLine(); } catch (Exception ex) { Console.Write("ERROR: " + ex.Message + "\nPress any key to exit"); Utils.WriteErrLog(ex); Console.ReadLine(); } finally { //Close and free connection oracon.Close(); oracon.Dispose(); } }
/// <summary> /// Creates the database file that contains meta data about the shapes. /// </summary> /// <param name="shapetype"></param> /// <param name="SHPFile"></param> private void WriteDBF(ShapeLib.ShapeType shapetype, string SHPFile, bool convertTags) { string filename; int shapes = 0; List <MetaData> elementData; List <string> fields = new List <string>(); switch (shapetype) { case ShapeLib.ShapeType.Polygon: filename = SHPFile + "-polygons"; shapes = areas; elementData = polygonsData; break; case ShapeLib.ShapeType.PolyLine: filename = SHPFile + "-lines"; shapes = ways; elementData = linesData; break; case ShapeLib.ShapeType.Point: filename = SHPFile + "-points"; shapes = points; elementData = pointsData; break; default: return; } IntPtr hDbf = ShapeLib.DBFCreate(filename); if (hDbf.Equals(IntPtr.Zero)) { Console.WriteLine("Error: Unable to create {0}.dbf!", filename); return; } // add some fields. Fields have to be initialized before data is added int iRet = ShapeLib.DBFAddField(hDbf, "shapeID", ShapeLib.DBFFieldType.FTInteger, 4, 0); iRet = ShapeLib.DBFAddField(hDbf, "shapeName", ShapeLib.DBFFieldType.FTString, 50, 0); // if tags have to be converted, collect the names of all tags if (convertTags) { for (int iShape = 0; iShape < shapes; iShape++) { foreach (KeyValuePair <string, string> entry in elementData[iShape].Tags) { // Make sure that fields are only added once if (!fields.Contains(entry.Key)) { fields.Add(entry.Key); } } } // create fields in the DB for all tags foreach (string field in fields) { iRet = ShapeLib.DBFAddField(hDbf, field, ShapeLib.DBFFieldType.FTString, 128, 0); } } // populate for (int iShape = 0; iShape < shapes; iShape++) { iRet = (ShapeLib.DBFWriteIntegerAttribute(hDbf, iShape, 0, iShape)); iRet = (ShapeLib.DBFWriteStringAttribute(hDbf, iShape, 1, elementData[iShape].Name)); // If tags should be converted, write their values to the appropriate fields if (convertTags) { foreach (KeyValuePair <string, string> entry in elementData[iShape].Tags) { // Cut the entry after 128 characters int stringLength = entry.Value.Length; if (stringLength > 127) { stringLength = 127; } iRet = ShapeLib.DBFWriteStringAttribute(hDbf, iShape, fields.IndexOf(entry.Key) + 2, entry.Value.Substring(0, stringLength)); } } } ShapeLib.DBFClose(hDbf); }