using ExportMap.db; using ExportMap.Models; using System; using System.Collections.Generic; using System.Configuration; using System.Data; using System.Diagnostics; using System.IO; using System.Linq; using System.Threading; using System.Web; namespace ExportMap.cs { public class SGUtils { /// /// Mpt目录 /// public static string MptPath { get { return ConfigurationManager.AppSettings["mptFolder"]; } } /// /// 3DML目录 /// public static string D3mlFolder { get { return ConfigurationManager.AppSettings["3dmlFolder"]; } } /// /// 廊坊数据目录 /// public static string LFData { get { return ConfigurationManager.AppSettings["lfData"]; } } /// /// SG的DB库 /// public static string SGDB { get { return ConfigurationManager.AppSettings["sgDB"]; } } /// /// 获取发布地址 /// public static string GetReleaseUrl(SysMeta meta, Int64 sgsID) { switch (meta.type) { case "mpt": return "http://{host}/SG/Imagery;" + sgsID + ".mpt"; // Elevation case "3dml": return "http://{host}/SG/b3dm/" + sgsID + "/tileset.json"; default: return string.Empty; } } /// /// 发布数据 /// /// XYZ参数 /// 行数 public int Release(XYZArgs args, ref string err) { List list = XYZUtils.selectMetas(args.ids, "and type in ('mpt', '3dml')"); if (null == list || list.Count == 0) return 0; int maxId = GetMaxId(); maxId = 411576; // RomoveNoneFiles(list); if (list.Count == 0) return 0; err = LinkFiles(list); if (!string.IsNullOrEmpty(err)) return 0; int count = 0; for (int i = 0; i < 25; i++) { Thread.Sleep(3000); List items = SelectItems(maxId); if (null == items || items.Count == 0) continue; InsertInto(list, items, args); count = items.Count; break; } return count; } /// /// 获取最大ID值 /// public int GetMaxId() { Object obj = SQLiteHelper.ExecuteScalar("select max(id) from SpatialItems"); return null == obj ? 0 : Convert.ToInt32(obj); } /// /// 查询SG数据项 /// /// 最大ID值 /// SG数据项 public List SelectItems(int maxId) { string sql = string.Format("select id, Name, RelativePath, LayerName, DataSourceId, Description from SpatialItems where id > {0} order by id desc", maxId); DataTable dt = SQLiteHelper.GetDataTable(sql); List list = ModelHandler.FillModel(dt); return list; } /// /// 移除空文件 /// private void RomoveNoneFiles(List list) { string uploadFolder = Tool.GetSetting("uploadFolder"); int i = 0; while (i < list.Count) { SysMeta meta = list[i]; string filePath = Path.Combine(uploadFolder, meta.path); if (!File.Exists(filePath)) { list.RemoveAt(i); continue; } if ("mpt".Equals(meta.type)) { string midx = Path.Combine(uploadFolder, meta.path.Replace(".mpt", ".midx")); string strmi = Path.Combine(uploadFolder, meta.path.Replace(".mpt", ".strmi")); if (!File.Exists(midx) || !File.Exists(strmi)) { list.RemoveAt(i); continue; } } i++; } } /// /// 链接文件 /// private string LinkFiles(List metas) { List list = new List(); foreach (SysMeta meta in metas) { switch (meta.type) { case "3dml": AddMptLinkFile(list, meta); break; case "mpt": AddD3mlLinkFile(list, meta); break; } } if (0 == list.Count) return "没有需要更新发布的文件"; return Tool.ExecCmd(list); } /// /// 添加链接文件 /// private void AddMptLinkFile(List list, SysMeta meta) { string uploadFolder = Tool.GetSetting("uploadFolder"); string d3mlFolder = Tool.GetSetting("3dmlFolder"); string targetFolder = Path.Combine(d3mlFolder, meta.id.ToString()); if (!Directory.Exists(targetFolder)) Directory.CreateDirectory(targetFolder); string d3ml = Path.Combine(uploadFolder, meta.path); string targetD3ml = Path.Combine(d3mlFolder, meta.id.ToString(), meta.name); if (!File.Exists(targetD3ml)) list.Add(string.Format("mklink \"{0}\" \"{1}\"", targetD3ml, d3ml)); // /H } /// /// 添加链接文件 /// private void AddD3mlLinkFile(List list, SysMeta meta) { string uploadFolder = Tool.GetSetting("uploadFolder"); string mptFolder = Tool.GetSetting("mptFolder"); string targetFolder = Path.Combine(mptFolder, meta.id.ToString()); if (!Directory.Exists(targetFolder)) Directory.CreateDirectory(targetFolder); string mpt = Path.Combine(uploadFolder, meta.path); string targetMpt = Path.Combine(mptFolder, meta.id.ToString(), meta.name); string midx = Path.Combine(uploadFolder, meta.path.Replace(".mpt", ".midx")); string targetMidx = Path.Combine(mptFolder, meta.id.ToString(), meta.name.Replace(".mpt", ".midx")); string strmi = Path.Combine(uploadFolder, meta.path.Replace(".mpt", ".strmi")); string targetStrmi = Path.Combine(mptFolder, meta.id.ToString(), meta.name.Replace(".mpt", ".strmi")); if (!File.Exists(targetMpt)) list.Add(string.Format("mklink \"{0}\" \"{1}\"", targetMpt, mpt)); if (!File.Exists(targetMidx)) list.Add(string.Format("mklink \"{0}\" \"{1}\"", targetMidx, midx)); if (!File.Exists(targetStrmi)) list.Add(string.Format("mklink \"{0}\" \"{1}\"", targetStrmi, strmi)); } /// /// 插入数据发布表 /// private void InsertInto(List list, List items, XYZArgs args) { foreach (SysMeta meta in list) { SpatialItem si = (from item in items where meta.name.Equals(item.Name) select item).First(); if (null == si) continue; meta.verid = si.id; InsertToDB(meta, args); } } /// /// 插入数据库 /// private static void InsertToDB(SysMeta meta, XYZArgs args) { if (PubDBHelper.IsPublish(meta.id)) return; SysPublish sys = NewPublish(meta, args); sys.path = meta.id + "\\" + meta.name; int pubid = PubDBHelper.InsertPublish(sys); if (pubid > 0) { PubDBHelper.InsertMetaPub(meta.id, pubid, args.userId); } } /// /// 创建数据发布类 /// private static SysPublish NewPublish(SysMeta meta, XYZArgs args) { SysPublish sp = new SysPublish(); sp.name = meta.name; sp.url = GetReleaseUrl(meta, meta.verid); sp.type = meta.type; sp.status = 3; sp.dirid = meta.dircode; sp.depid = args.depcode; sp.min = 0; sp.max = 0; sp.json = null; sp.create_user = args.userId; sp.geom = null; sp.bak = null; return sp; } } }