[GIS] FingerEyes, 타일맵 레이어 추가

타일맵 레이어는 수치지도나 항공영상을 이용해 만들어진 지도를 일정한 크기(격자)의 잘라 미리 만들어 놓은 그림으로 구성됩니다. 수치지도나 항공영상을 굳이 타일 이미지로 미리 가공해 사용하는 이유는 다음과 같습니다.

  • 미리 만들어진 지도이므로 네트워크 상에서 빠르게 서비스 할 수 있음
  • 단순한 이미지 파일이므로 쉽고 빠르게 화면상에 표시할 수 있음
  • 단순한 이미지 파일이므로 서버와 클라이언트 단에 부하가 매우 적음
  • 한번 만들어지면 변경할 수 없다는 문제가 있음

이러한 이유들로 타일맵은 대부분 배경 지도로 사용됩니다. 예를 들어 타일맵으로 배경도를 구성하고 이 위에 주제도나 시설물들을 올려 놓고 서비스를 제공하게 됩니다. 이 글은 바로 핑거아이즈에서 타일맵을 구성하는 API에 대해서 설명드리고자 합니다.

사용자 삽입 이미지
먼저 Package Explorer에 나타난 폴더 중 src 폴더 에서 오른쪽 버튼을 눌러 나타난 팝업 메뉴 중 MXML Application을 선택해 MXML 어플리케이션을 하나 추가합니다. 아래 처럼 Name을 원하는 이름으로 주면 되는데 편의상 아래처럼 지정한 후 Finish 버튼을 눌러 추가합니다.

사용자 삽입 이미지

새롭게 추가된 Application의 소스 코드에서 핑거아이즈의 맵 컴포넌트를 추가하기 위해 네임스페이스를 지정합니다. 아래 코드에서 5번째 코드가 해당 코드입니다. 그 외 나머지 코드는 모두 원래 있던 코드입니다. (참고로 이 글은 핑거아이즈의 동적 라이브러리(.swc) 파일을 참조 하고 있다는 가정 하에 설명됩니다. 참조 하는 방법은 핑거아이즈 사용 준비하기를 참조 하시기 바랍니다)



    
    
    

이제 핑거아이즈에서 제공하는 맵 컴포넌트를 어플리케이션에 추가하기 위해 바로 위에 다음과 같은 코드를 추가합니다.

    ...

    
    
    

위의 코드에서 5번째 코드가 해당 코드로써 맵 컴포넌트의 크기를 어플리케이션에 꽉 채우도록 width와 height를 모두 100%로 지정했으며 위치를 좌상단 가장 코너쪽에 위치하도록 x와 y를 0으로 지정했습니다. 그리고 이 맵 컴포넌트를 다른 코드에서 map이라는 이름으로 쉽게 참조할 수 있도록 id를 map으로 주었습니다.

이제 타일맵 레이어를 추가하는 코드를 작성해 보도록 하겠습니다. 레이어를 추가하는 코드는 어플리케이션이 초기화되는 시점에서 이루어 지는것이 가장 합당하므로 어플리케이션의 초기화 이벤트를 추가합니다. 초기화 이벤트 코드를 모두 포함해 지금까지 진행된 모든 코드를 나타내면 아래와 같습니다.




    
    

    
    
    
    
    

추가된 초기화 코드는 7번 코드와 9~18번 코드입니다. 이제 초기화 코드인 onInit 매서드에 타일맵을 추가하는 코드를 작성하면 됩니다. 타일맵을 추가하는 코드 전체를 나타내면 다음과 같습니다.

import mx.events.FlexEvent;
import geoservice.view.layers.XrTileMapLayer;
import geoservice.base.XrCoordinate;
   
protected function onInit(event:FlexEvent):void
{
    var lyr:XrTileMapLayer = new XrTileMapLayer("basemap", 
        "http://www.geoservice.co.kr/seoul");
    map.layers.addLayer(lyr);
    
    map.viewControls.scaleLevels = [120000, 60000, 25000, 15000, 7000, 2500, 1200];
    map.moveMap(new XrCoordinate(958581, 1945902));
    map.viewControls.scaleLevel = 5; 
}

새롭게 추가된 코드를 자세히 설명드리면….. 타일맵 레이어에 해당하는 클래스의 이름은 XrTileMapLayer로써 7번 코드에서 타일맵 레이어를 생성하고 있습니다. XrTileMapLayer 생성자는 두개의 인자를 가지며 첫번째 인자는 레이어의 이름이고 두번째 인자는 타일맵을 서비스하는 서버의 url입니다. 이 글을 위해 간단히 서울시에 대한 타일맵을 테스트 형식으로 서비스 하는 것을 이용했습니다. 그리고 이렇게 만들어진 레이어를 9번 코드를 통해 추가합니다. 그리고 11번 코드는 서비스되는 타일맵을 구성하고 있는 축척값에 대한 분모수입니다. 총 7단계의 축척 레벨로 서비스 되고 있다는 것을 알 수 있습니다. 12번 코드는 가장 처음 사용자에게 보여질 지도의 위치이며 13번 코드는 가장 처음 사용자에게 보여질 축척 레벨입니다. 축척 레벨은 0부터 시작합니다. 즉 위의 코드의 경우 5이므로 1:2500 축척 단계의 지도를 보여주게 됩니다.

이제 실행(F11)해 보면 다음 그림처럼 지도가 표시되고.. 마우스 왼쪽 버튼과 휠을 통해 지도 이동 및 확대/축소가 가능합니다.

사용자 삽입 이미지실행 결과 및 소스코드 보기

실제 코드는 매우 간단한데 설명을 가능한 자세히 한다고 해서 그런지 복잡한듯합니다.

[GIS] FingerEyes, 핑거아이즈 사용 준비하기

핑거아이즈 API에 대한 첫번째 튜토리얼로써 가볍게 핑거아이즈를 사용하기 위한 설정에 대해 설명해 드리겠습니다. 핑거아이즈에 관심을 가져 주시고 이 글을 읽어 주신 분들에게 먼저 감사드립니다!

먼저 플래시 빌더에서 핑거아이즈에 대한 동적 라이브러리를 사용해야 합니다. 핑거아이즈에 대한 동적 라이브러리는 확장자가 .swc이며 다음 url에서 다운로드 받을 수 있습니다.

핑거아이즈는 이미 관공서 등의 GIS 시스템 구축 프로젝트에 사용되어 이미 검증된 맵엔진입니다. 하지만 앞으로 계속 발전되고 개선되어 나가고 있으므로 항상 최신버전을 확인하시고 받아 사용하시길 권장해 드립니다.

원하는 폴더를 만든 후 해당 폴더에 핑거아이즈 동적 라이브러리(.swc)를 다운로드 받습니다. 아니면 다운로드 받으신 후 원하는 폴더에 복사하셔도 됩니다. 그리고 플래시 빌더(Flash Builder)를 실행한 후 [File]-[New]-[Flex Project] 메뉴를 실행합니다.

사용자 삽입 이미지
Flex Project를 실행하면 다음과 같은 대화창이 나타납니다. 이 대화창에서 프로젝트가 생성될 폴더와 프로젝트 이름을 지정한 후 Finish 버튼을 클릭하여 새로운 프로젝트를 생성합니다.

사용자 삽입 이미지
이제 핑거아이즈의 동적 라이브러리 파일(.swc)를 참조하기 위해 [Project]-[Properties] 메뉴를 실행합니다.

사용자 삽입 이미지
Properties 메뉴를 실행하게 되면 다음과 같은 창이 나타납니다. 여기서 아래의 화면처럼 (1) Flex Build Path 항목을 선택하고 (2) Add SWC … 버튼을 누르면 나타나는 Add SWC 대화상자에서 (3) Browse 버튼을 눌러 다운로드 받은 핑거아이즈의 라이브러리 파일인 XrMap_version.swc 파일을 찾아서 지정하고 (4) OK 버튼을 눌러주면 됩니다.

사용자 삽입 이미지
자.. 이제 Properties 대화상자를 닫기 위해 OK 버튼 눌러 닿으면 핑거아이즈를 사용할 모둔 준비가 와료된 것입니다. 이제 다음 글을 통해 핑거아이즈에 대한 재밌는 기능에 대해 하나 하나 설명해 드리겠습니다.

[GIS] 지오서비스, 플래시 기반의 GIS 솔루션 납품

지오서비스(대표 김형준)은 플래시 기반의 GIS 솔루션인 핑거아이즈(FingerEyes)를 개발하고 이를 한진정보통신의 지자체에서 발주한 공간정보 인트라넷 시스템 개발의 맵 솔루션으로 채택되었으며 성공적으로 개발을 완료하였다.

사용자 삽입 이미지
핑거아이즈가 적용된 공간 정보시스템은 25cm급 고해상도 항공영상과 수치지도를 기본도로 하여 기반 시설물인 상수, 하수 그리고 도로를 관리하고 건물명 그리고 새주소와 지번을 검색할 수 있다.

공간 데이터에 대한 분석이나 편집등과 같은 고급 GIS 기능이 필요한 기존의 GIS 시스템은 대부분 ActiveX 기반의 GIS 솔루션이 사용되어왔다. 그러나 ActiveX는 악의적인 코드로 보안상의 문제를 발생시킬 수 있으며 마이크로소프트사의 IE에서만 구동 된다는 점 그리고 특정한 환경에서 설치가 제대로 되지 않아 사용자에게 불편을 초래하는 문제점 등이 제기 되어 왔다.

이를 해결하기 위해 인터넷이 되는 99%의 PC에 이미 설치되어 있는 플래시를 사용해 개발된 핑거아이즈는 인터넷 익스플로러와 크롬, 파이어폭스, 사파리 등과 같은 대부분의 인터넷 브라우저에서 실행되며 GIS 시스템 전반에 필요로 하는 공간분석, 공간 데이터 편집, 시설물 등을 지도에 매쉬업하는 기능 등을 제공한다.

또한 핑거아이즈는 자체 공간서버를 이용할 수 있으면서 동시에 ArcSDE와 같은 기존의 공간서버를 그대로 활용할 수 있다는 점이 있어 기존에 ActiveX로 개발된 시스템을 핑거아이즈로 유지보수하는데 어려움이 없도록 하였다.

[GIS] 거리 매트릭스(Matrix) 산출 툴

여기서 언급하는 거리 매트릭스는 공간상에 존재하는 점들 간의 모든 거리를 쉽게 계산한 행렬 형태의 결과를 말합니다. 대학원 논문을 쓰시는 분이 도움을 요청하셔서 만들어 놓은 프로그램인데.. 혹 이런 기능을 필요로 하시는 다른 분들도 있을지 싶어 공유해 봅니다. 듀라맵으로 만들었으므로 듀라맵을 먼저 설치하신 후 실행하시기 바랍니다. (듀라맵 다운로드)

사용자 삽입 이미지

위의 첨부 파일에 소스 코드와 컴파일된 실행 파일이 함께 들어있습니다. 입력할 레이어는 SHP 파일로 포인트 타입이여야 합니다. 만약 주소 데이터를 가지고 계신다면.. 지오코딩을 통해 포인트 SHP로 변환활 수 있습니다. 결과 파일 형식은 CSV로 엑셀에서 열어 보면 다음과 같습니다. (지오코딩 툴 다운로드)

사용자 삽입 이미지
그럼 필요로 하시는 분에게 도움이 되길 바랍니다.