Pular para o conteúdo principal

Geoprocessamento no Delphi

No último artigo referente à geoprocessamento tivemos uma pincelada sobre alguns dos principais conceitos e aplicações possíveis, agora chegou o momento de colocar a mão na massa.
Neste primeiro artigo prático iremos mostrar alguns componentes gratuitos, descrevendo suas funcionalidade e apresentando exemplos, o primeiro a ser visto será o Shape Viewer Objects (SVO), então mãos a obra!

Shape Viewer Objects™ (SVO)
A empresa Ecological Software Solutions LLC disponibilizou vários de seus componentes, assim como seus respectivos códigos fonte, e podem ser utilizados para fins comerciais. Existem alguns exemplos que acompanham o pacote de instalação, mas a utilização desses componentes requer uma certa dedicação.
A instalação é simples:
  • Execute o programa, para extrair os arquivos;
  • Ao final de extração teremos três pastas, Demo, Help e Source;
  • Abra a pasta Source e execute o arquivo .DPK, a primeira mensagem será para permissão de conversão, confirme, depois compile e instale, pronto agora é só usar;

(a)- Paleta ESS com os objetos após a instalação


Principais componentes do SVO

TGISReadWrite
TGISReadWrite
É o motor geoespacial GIS. Com ele é possível ler e escrever:
  • Arquivos ESRI Shape
  • Arquivos MapInfo
  • DXF DXF
  • Arquivos ASCII
  • Qualquer banco de dados SQL via e TDataset objeto ou descendente.
  • Passthrough OnReadExcel, especificamente para apoiar Excel.
  • Passthrough OnReadShape para apoio de qualquer tipo de arquivo definido.
TSVOShapeObject (non-visual) TSVOShapeObject (não-visuais)
Objeto básico. TSVOPointShape, TSVOLineShape, TSVOPolygonShape (total apoio à formas aninhadas), e TSVOMultipointShape todos são descendentes de TSVOShapeObject. Todos os TSVOShapeObjects podem ser criados independente, ou incluídos a uma TSVOShapeList (ver abaixo). A classe TSVOShapeObject contém todas as funções necessárias de abertura propriamente ditas, incluindo cores e estilos, em qualquer TCanvas, além da nova propriedade TSVOShapeList.
Os dados para polilinhas e polypoints são armazenados em uma matriz dinâmica, essa matriz dinâmica tem inúmeras funções internas para permitir a alteração em profundidade da matriz, permitindo alterações de forma mais rápida. Assim, você pode facilmente criar e manipular formas no decorrer do processo em seus aplicativos, e não apenas carregá-los a partir de arquivos.
TSVOShapeList (non-visual) TSVOShapeList (não-visuais)
Objeto não visual e um descendente de TPersistent. Funciona como um recipiente para TShapeObjects. Tem inúmeras funções de gestão de uma coleção de TShapeObjects. Um único TShapeList funciona como um única "Layer" no TGISImage.
O ShapeList mantém a maior parte do poder de transformação, contém a maior parte dos métodos importantes usados para manipular o ShapeObjects sob o seu controle.


TSVOGISImage TSVOGISImage
Um TCustomControl descendente. Usado para exibir camadas de um TShapeList. Tem zoom instantaneo, é possível agarrar e avançar, identificar forma Suporte para Lat / Long baseado em metros (por exemplo, UTM). Projeção interna de conversão. Algoritmos Datum de conversão.


TSVODataGrid TSVODataGrid
TDrawGrid descendente. Usado para exibir dados de um TShapeList. Você também pode ligar os dados usando um ponteiro para um TDataset, e exibir os dados em um TTable, mas TSVODataGrid tem suporte aperfeiçoado para multiselect, copiar, colar, adicionar colunas e linhas. Isso permite que as suas aplicações e seus usuários a interajam com os dados GIS. Também pode ser utilizado como uma planilha autônoma bem como, através da definição de que é "ownsdata" com a propriedade "true".

TDataFileList
TDataFileList
TSVOShapeLists permite a manipulação e armazenamento de Shapes.


T
SVOLegend TSVOLegend
Você pode exibir seus dados usando o Windows ® TListView, mas para um controle otimizado você pode usar o SVO TSVOLegend.
Abaixo podemos ver uma das aplicações de demonstração que acompanha esse pacote (GisApp.dpr), nós carregamos um mapa que acompanha o exemplo depois mostramos as informações em um formulário a parte.
(b)- Aplicação de Demosntração GisApp

No próximo artigo veremos outro componente open source para o Delphi, o MapWindow, até a próxima...
OBS.: Este artigo se utilizou de uma adaptação do conteúdo do site da empresa proprietária do componente, qualquer retificação do conteúdo será bem vinda.

Comentários

  1. Opa, quando colocar o artigo sobre mapwin coloque exemplos, pois no site dele só tem em vb, abraços.

    ResponderExcluir
  2. Hã??????

    Desculpe, meu amigo. Não cheguei ainda no estágio de compreender essas coisas, mas acho que daqui a umas 3 encarnações, já estarei apto.
    Muito obrigado pelas visitas e vou continuar passando por aqui, sim, pois quem sabe acabo aprendendo.
    Um abraço e um ótimo feriadão!

    ResponderExcluir
  3. muito bom esses componentes heim, depois vou dar uma olhaa melhor neles!!!

    marcelofrasson@gmail.com

    ResponderExcluir

Postar um comentário

Obrigado por Participar do programero, fique a vontade para agradecer, retificar, perguntar ou sugerir.

Mais visitadas

Array no PL/SQL (Oracle)

Trabalhar com estruturas indexadas pode nos poupar muito trabalho, deixar o código mais limpo e reutilizável, pois bem vamos dar um exemplo de como fazer isso no PL/SQL. Criaremos um tipo table que seja capaz de armazenar nomes de uma tabela de funcionários de forma indexada, e em seguida mostraremos o que foi armazenado, segue o código: 1: declare 2: -- tipo tabela contendo apenas texto e indexado 3: type TipoNomFunc is table of varchar 2(200) index by binary_integer; 4: -- variável do nosso tipo (como nosso tipo é indexado ele funcionará como um array) 5: func TipoNomFunc; 6: -- indice para loop 7: indice number := 1; 8: -- 9: begin 10: -- 11: -- cursor para nossa tabela de funcionarios 12: for emps in ( 13: select * 14: from funcionarios 15: ) 16: loop 17: -- colocamos o nome do funcionario em nosso "vetor" 18: func(indice) := emps.nom_funcionario; 19: -- incrementamos o indice 20:...

Criando uma Aplicação CRUD com Flask, PostgreSQL e Docker

Criando uma Aplicação CRUD com Flask, PostgreSQL e Docker Neste guia, vamos criar uma aplicação básica que acessa um banco de dados PostgreSQL e realiza operações CRUD (Create, Read, Update, Delete). Vamos usar Flask e executar tudo com Docker. Sem estilos ou extras, apenas o essencial. Estrutura do Projeto crud-app/ |-- app/ | |-- app.py | |-- templates/ | | |-- index.html | | |-- edit.html |-- Dockerfile |-- requirements.txt |-- docker-compose.yml Passo 1: Dependências Crie um arquivo requirements.txt com as seguintes linhas: Flask==2.2.2 Flask-SQLAlchemy==3.0.2 psycopg2-binary==2.9.3 Werkzeug==2.2.2 Passo 2: Aplicação Flask Arquivo app/app.py : from flask import Flask, render_template, request, redirect, url_for from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) # Configuração do banco de dados app.config['SQLALCHEMY_DATABASE_URI'] = 'postgresql://user:password@db:5432/crud_db' app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False db...

Listar arquivos existentes em diretório (Delphi)

Mostraremos uma maneira simples e prática para listar o conteúdo de um diretório com a opção de incluir nessa listagem os arquivos de seus subdiretórios. No exemplo abaixo temos um Edit para receber o diretório a ser pesquisado um CheckBox para indicar se os subdiretórios entrarão na pesquisa um botão para efetuar a pesquisa e um Memo para listar os arquivos encontrados, no final um Edit que receberá o cálculo final (em bytes) da soma do tamanho dos arquivos. procedure TForm1.Button1Click(Sender: TObject); begin   tamanhoTotal := 0;   memLista.Lines.Clear;   ListarArquivos(edtDiretorio.Text, chkSub.Checked);   Edit1.Text := IntToStr( tamanhoTotal ); end; procedure TForm1.ListarArquivos(Diretorio: string; Sub:Boolean); var   F: TSearchRec;   Ret: Integer;   TempNome: string; begin   Ret := FindFirst(Diretorio+'\*.*', faAnyFile, F);   try     while Ret = 0 do ...