Я пытаюсь найти наиболее эффективный способ загрузки геометрии полилиний 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
Загрузка полилиний геопакета в ThinkGeo InMemoryFeatureLayer для использования с ThinkGeo.UI.WinForms.MapView в C# ⇐ C#
Место общения программистов C#
1731599772
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();
}
}
}
...
...
...
Подробнее здесь: [url]https://stackoverflow.com/questions/79182792/loading-geopackage-polylines-into-thinkgeo-inmemoryfeaturelayer-for-use-with-thi[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия