From ecfe110922f3c542df7aaef9ac9e26cdb0b73e55 Mon Sep 17 00:00:00 2001
From: 13693261870 <252740454@qq.com>
Date: 星期六, 20 七月 2024 09:52:58 +0800
Subject: [PATCH] 1

---
 SimuTools/Tools/Handle.cs |   53 ++++++++++++++++++++++++++++-------------------------
 1 files changed, 28 insertions(+), 25 deletions(-)

diff --git a/SimuTools/Tools/Handle.cs b/SimuTools/Tools/Handle.cs
index 1ea8f07..74796fc 100644
--- a/SimuTools/Tools/Handle.cs
+++ b/SimuTools/Tools/Handle.cs
@@ -92,7 +92,8 @@
             foreach (int[] sizes in layer.terrain.size)
             {
                 string tif = Path.Combine(tempPath, DateTime.Now.Ticks.ToString() + ".tif");
-                Resample(ds.GetDescription(), tif, sizes[0], sizes[1]);
+                //Resample(ds.GetDescription(), tif, sizes[0], sizes[1]);
+                Resample(ds, tif, sizes[0], sizes[1]);
                 if (!File.Exists(tif))
                 {
                     continue;
@@ -105,6 +106,32 @@
 
         /// <summary>
         /// 閲嶉噰鏍�
+        /// </summary>
+        private static void Resample(Dataset ds, string dest, int width, int height)
+        {
+            // https://blog.51cto.com/u_16099346/6691820
+            //string args = string.Format("-t_srs {0} -ts {1} {2} -r {3} -of {4}", "EPSG:4326", width, height, "bilinear", "GTiff");
+            //string[] options = Gdal.ParseCommandLine(args);
+            string[] options = new string[]
+            {
+                "-t_srs",
+                "EPSG:4326",
+                "-ts",
+                width.ToString(),
+                height.ToString(),
+                "-r",
+                "bilinear",
+                "-of",
+                "GTiff"
+            };
+            GDALWarpAppOptions warpAppOptions = new GDALWarpAppOptions(options);
+
+            Dataset destDs = Gdal.Warp(dest, new Dataset[] { ds }, warpAppOptions, null, null);
+            destDs.Dispose();
+        }
+
+        /// <summary>
+        /// 閲嶉噰鏍� *
         /// </summary>
         private static void Resample(string source, string dest, int width, int height)
         {
@@ -438,30 +465,6 @@
             {
                 sw.Write(json);
             }
-        }
-        #endregion
-
-        #region 鏆傛椂涓嶇敤
-        /// <summary>
-        /// 閲嶉噰鏍� *
-        /// </summary>
-        private static void Resample(Dataset ds, string dest, int width, int height)
-        {
-            // 璁剧疆Warp鐨勯�夐」锛歨ttps://blog.csdn.net/qq_43210879/article/details/121350561
-            string[] options = new string[] {
-                "format=GTiff",
-                "width=" + width,
-                "height=" + height,
-                "dstSRS=EPSG:4326"
-            };
-
-            OSGeo.GDAL.Driver driver = Gdal.GetDriverByName("GTiff");
-            Dataset destDs = driver.Create(dest, width, height, ds.RasterCount, ds.GetRasterBand(1).DataType, null);
-
-            GDALWarpAppOptions warpAppOptions = new GDALWarpAppOptions(options);
-            Gdal.Warp(destDs, new Dataset[] { ds }, warpAppOptions, null, null);
-
-            destDs.Dispose();
         }
         #endregion
     }

--
Gitblit v1.9.3