Загрузка полилиний геопакета в ThinkGeo InMemoryFeatureLayer для использования с ThinkGeo.UI.WinForms.MapView в C#C#

Место общения программистов C#
Ответить Пред. темаСлед. тема
Anonymous
 Загрузка полилиний геопакета в ThinkGeo InMemoryFeatureLayer для использования с ThinkGeo.UI.WinForms.MapView в C#

Сообщение Anonymous »

Я пытаюсь найти наиболее эффективный способ загрузки геометрии полилиний Geopackage в ThinkGeo InMemoryFeatureLayer. У меня есть рабочее решение, использующее набор/самородки Microsoft Sqlite и NetTopologySuite. Я ищу решение, которое будет напрямую загружать базу данных геопакетов в InMemoryFeatureLayer.
...
...
...

using Microsoft.Data.Sqlite;
using NetTopologySuite.Geometries;
using NetTopologySuite.IO;
using ThinkGeo.Core;
using ThinkGeo.UI.WinForms;

...
...
...

GeoPackageGeoReader gpkgReader = new GeoPackageGeoReader(); // for reading geopackage blob
WKBWriter wkbWriter = new WKBWriter(); // for converting the GeoPackageGeoReader to standard wkb

using (SqliteConnection SQLiteConnection = new SqliteConnection(@"Data Source=:memory:"))
{
using (SqliteCommand SQLiteCommand = new SqliteCommand())
{
SQLiteCommand.CommandText =
$@"

ATTACH 'c:\temp\lines.gpkg' as lines_;
CREATE TEMP TABLE IF NOT EXISTS lines
AS SELECT * FROM lines_.lines;
DETACH lines_;

SELECT
fid,
_ogr_geometry_,
street
FROM lines;

";

SQLiteCommand.Connection = SQLiteConnection;
SQLiteConnection.Open();

using (SqliteDataReader SQLiteDataReader = SQLiteCommand.ExecuteReader())
{
while (SQLiteDataReader.Read())
{
string id = SQLiteDataReader["fid"].ToString();
byte[] geomData = (byte[])SQLiteDataReader.GetValue("_ogr_geometry_");

Geometry geometry = gpkgReader.Read(geomData); // get the geometry from the GeoPackage blob
byte[] standardWkb = wkbWriter.Write(geometry); // convert the gpkg blob to standard WKB

Feature polyLineFeature = new Feature(standardWkb, id);
polyLineFeature.Id = id;

for (int i = 0; i < SQLiteDataReader.FieldCount; i++)
{
string columnName = SQLiteDataReader.GetName(i);
object value = SQLiteDataReader.GetValue(i);

string valueAsString = value switch
{
null or DBNull => string.Empty, // handling null and DBNull values
string str => str, // use it as is
_ => value.ToString() // default - convert to string
};

polyLineFeature.ColumnValues.Add(columnName, valueAsString); // adding columns to feature
}
InMemoryFeatureLayer.InternalFeatures.Add(polyLineFeature); // adding row to InMemoryFeatureLayer
}
InMemoryFeatureLayer.BuildIndex();
}
}
}

...
...
...


Подробнее здесь: https://stackoverflow.com/questions/791 ... e-with-thi
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Могут ли геопанды получить все слои геопакета (или другого векторного файла)?
    Anonymous » » в форуме Python
    0 Ответы
    17 Просмотры
    Последнее сообщение Anonymous
  • QgsVectorLayerExporter с файлом геопакета
    Anonymous » » в форуме Python
    0 Ответы
    18 Просмотры
    Последнее сообщение Anonymous
  • Показать вид Земли (сферу) с помощью маркеров и полилиний
    Anonymous » » в форуме JAVA
    0 Ответы
    19 Просмотры
    Последнее сообщение Anonymous
  • Показать вид Земли (сферу) с помощью маркеров и полилиний
    Anonymous » » в форуме Android
    0 Ответы
    12 Просмотры
    Последнее сообщение Anonymous
  • Показать вид Земли (сферу) с помощью маркеров и полилиний
    Anonymous » » в форуме JAVA
    0 Ответы
    22 Просмотры
    Последнее сообщение Anonymous

Вернуться в «C#»