1월, 2014의 게시물 표시

공간정보거점대학교육 - PyQGIS 및 Plugin 개발

1월 20 ~ 24일간 진행했던 국토교통부 공간정보 거점대학 [오픈 소스 GIS 심화 과정] 중  [QGIS 고급 & PyQGIS(QGIS 분석도구, PyQGIS 스크립트 & 플러그인)] 교재입니다. 공간정보거점대학 - PyQGIS 및 플러그인 개발 from Minpa Lee

[PostGIS] Custom Function for Reprojecting Geometry Table

이미지
PostGIS를 사용하면서 약 300여개의 레이어(Geometry Table)의 좌표계를 한꺼번에 변환할 일이 생겨서 하나씩 작업하려다 좌표를 변환하는 함수( UpdateGeometrySRID 함수처럼 단순히 좌표를 정의하는 함수가 아니고 물리적으로 좌표변환를 수행)를 하나 만들어 봤습니다. PostGIS 2.0 이상부터는 다음과 같은 DDL 함수를 이용하여 좌표를 변환할 수 있으나 아래 붉은색으로 표시된 부분을 각각의 레이어마다 지정해야 주어야 하는 번거로움이 있습니다.    ALTER TABLE roads       ALTER COLUMN geom TYPE geometry( MultiLineString , 3857 )          USING ST_Transform( geom , 3857 ); 아래 과정을 따라 하면 데이터베이스 내의 모든 레이어에 대한 좌표변환을 수행할 수 있습니다. ▣ Download  - PostGIS_TransformGeometryTable.sql  - PostGIS_TransformGeometryTable_All.sql ▣ Install Functions  - pgAdmin을 실행한 후 적용할 Database에 연결  - Query Tool(Ctrl-E) 실행 후 다운로드한 SQL(2개 파일)을 각각 실행하여 함수 등록  - 등록된 함수 화면 ▣ Usages  ⊙  TransformGeometryTable  - 하나의 레이어에 대해서 좌표변환 수행  - 아래 예에서 public은 스키마, roads는 테이블, 3857(구글 좌표계)은 변환할 EPSG 코드이며, 스키마를 생략하면 현재 활성화된 스키마를 사용함  - SELECT TransformGeometryTable( 'public'...

[QGIS] Create Ring Maps using PyQGIS Script

이미지
공간정보 거점대학 오픈 소스 GIS 고급 과정 교재 작성 중  PyQGIS 샘플 스크립트를 작성하면서 좋은 예제가 없을까 살펴보다  Looking at Temporal Changes 블로그를 보게 되었습니다. 기존 샘플의 단계를 좀 더 줄이고, 하나의 폼에 여러 옵션을 생각해 봤습니다. Python 및 PyQGIS를 배우고 있으며, 오류가 있을 수 있으므로 잘못된 코드가 있으면 알려 주시기 바랍니다. ▣ Reference  - http://gis.stackexchange.com/questions/6682/how-to-implement-ringmaps-in-arcgis  - http://www.esri.com/esri-news/arcuser/fall-2013/looking-at-temporal-changes   - http://www.esri.com/news/arcuser/0408/files/ringmaps.pdf  - http://mapmaker.rutgers.edu/356/battersby_ringMaps.pdf   ▣ Download Script & Sample Dataset  - Script &  Dataset : https://www.dropbox.com/sh/hi892sh9usn9p8u/-xjo2yuHHy ▣ Usage ▶ 스크립트 생성  - 우선 QGIS 실행 후 [Processing] -> [Toolbox] 실행 후 [Scripts] -> [Tools] -> Create new script를 실행 - 다운로드한 샘플 스크립트를 불러온 후 저장하고 닫음 - 다음 그림과 같이 새로운 스크립트가 생성  - 첨부된 샘플 데이터셋을 불러온 후 스크립트 실행  ▶ Comma Separated Fields  - 아래 그림(샘플 데이터셋에 다음과 같이 구성되어 있음)과...

[Lifelog] Foursquare 2013년 메모

이미지
2013년 Foursquare 결산  - Badges: 109  - Mayorships: 126  - Friends: 498  - Pictures: 98  - Tips: 42  - 2014년 1월 1일 수퍼유저 레벨업 ▣ 약 5300번의 체크인 ▣ Profile (https://ko.foursquare.com/mapplus)