Microsoft MVP성태의 닷넷 이야기
.NET Framework: 143. WPF - Transform의 역변환 [링크 복사], [링크+제목 복사],
조회: 25708
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일


WPF - Transform의 역변환


Transform(예: ScaleTransform) 같은 것들은 지정된 규칙에 따라 입력 좌표를 다른 값으로 바꿀 수가 있습니다. 간단하게, 코드로는 다음과 같은 식으로 호출이 가능합니다.

ScaleTransform scaleTransform = [WPFElement].LayoutTransform as ScaleTransform;

Point pt = new Point(0, 0);
Point scaledPt = scaleTransform.Transform(pt);

보통, WPF에서는 다음과 같은 식으로 XAML상에서 하지요.

<Grid>
    <Grid.LayoutTransform>
        <ScaleTransform ScaleX="0.1" ScaleY="0.1"/>
    </Grid.LayoutTransform>
    ...
</Grid>

그런데, 때에 따라서는 위와 같이 계산된 결과의 역수가 필요한 경우가 있습니다. 즉, 10이란 값이 ScaleTransform을 거치면 1이 되었으니, 다시 1에서 10을 구하는 방법이 필요한 경우입니다.

이런 상황에 직면했는데, 왠지 특정 Transform에 종속적인 값(예를 들어, ScaleX, ScaleY)을 이용해서 역으로 계산해 내는 것은 왠지... ^^; 영 멋이 없어 보입니다.

그러다, GeneralTransform에 흥미로운 속성을 하나 발견했습니다.

GeneralTransform.Inverse 속성
; https://docs.microsoft.com/ko-kr/dotnet/api/system.windows.media.generaltransform.inverse

오호... 재미있군요. ^^
그래서, 다음과 같이 코드를 만들면 어떤 종류의 Transform을 사용했느냐에 관계없이 원래의 값을 구해낼 수가 있습니다.

GeneralTransform generalTransform = this.grid.LayoutTransform.Inverse;

Point pt = new Point(0.0, 0.0);
Point originalPoint = generalTransform.Transform(pt);

아래는 위의 코드를 간단하게 테스트한 예제 프로그램 화면입니다.

[그림 1: 레이아웃이 조정된 Grid 컨트롤]
wpf_inverse_transform_1.png

레이아웃 좌표계가 200%로 확대되었습니다. 이 때문에 Button의 ActualWidth는 179.5DIU(DIU: Device-Independent Units)로 설정되었지만 실제로 버튼의 Width 값을 표현하기 위해서 필요한 DIU는 359 DIU인 것입니다.

이렇게 359와 179.5 값을 서로 변환할 수 있는 방법이 이미 Transform 개체에는 제공된다는 것! (물론, 사용자 정의 Transform인 경우에 Inverse를 지원하지 않는 경우도 있을 수 있습니다.)

첨부된 파일은 위의 테스트 예제 솔루션입니다.



[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 7/17/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... [166]  167  168  169  170  171  172  173  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
925정성태9/8/201032354Team Foundation Server: 40. Visual Studio 2010 - Code Coverage 결과를 외부 XML 파일로 출력하는 명령행 도구 제작 [1]파일 다운로드1
924정성태9/6/201022545개발 환경 구성: 88. SCVMM이 설치된 도메인에 참여하지 않은 Hyper-V 호스트 추가
923정성태9/5/201028760오류 유형: 107. SCVMM Agent 설치 오류 - Failed to configure the WS-Management service.
922정성태9/4/201037385오류 유형: 106. Hyper-V 가상 머신의 네트워크 끊김 현상
921정성태9/2/201031258DDK: 2. Device Driver 응용 프로그램의 빌드 스크립트 [2]파일 다운로드1
920정성태9/1/201035969오류 유형: 105. WMI - The RPC server is unavailable [2]
919정성태8/30/201042085DDK: 1. Visual Studio 2010 - Device Driver 제작- Hello World 예제 [3]파일 다운로드1
918정성태8/28/201027947개발 환경 구성: 87. Hyper-V의 네트워크 유형 (3)
917정성태8/26/201023064개발 환경 구성: 86. "Routing and Remote Access"의 "Routing" 기능 활성화 방법
916정성태8/25/201022334개발 환경 구성: 85. 가상 네트워크에 LAN 어댑터 보이거나 감추는 방법
915정성태8/24/201040454개발 환경 구성: 84. Hyper-V의 네트워크 유형 (2)
913정성태8/22/201029560오류 유형: 104. Hyper-V 관리자 - VM 생성 오류 (VHD 생성 오류)
912정성태8/20/201031413.NET Framework: 183. 구조체 포인터 인자에 대한 P/Invoke 정의파일 다운로드1
911정성태8/19/201028458오류 유형: 103. System.Reflection.TargetException파일 다운로드1
910정성태8/19/201039322개발 환경 구성: 83. Hyper-V의 네트워크 유형 (1)
909정성태8/18/201034584오류 유형: 102. System.MissingMethodException
908정성태8/17/201025476개발 환경 구성: 82. Windows Virtual PC의 네트워크 유형 (3)
907정성태8/14/201022977개발 환경 구성: 81. Windows Virtual PC의 네트워크 유형 (2)
906정성태8/13/201031331개발 환경 구성: 80. Windows Virtual PC의 네트워크 유형 (1)
905정성태8/8/201034240Team Foundation Server: 39. 배치 파일로 팀 빌드 구성 [2]파일 다운로드1
904정성태8/8/201036850오류 유형: 101. SignTool Error: No certificates were found that met all the given criteria. [2]
903정성태8/6/201033763Team Foundation Server: 38. TFS 소스 코드 관리 기능 (4) - Branch
902정성태8/5/201026075Team Foundation Server: 37. TFS 2010의 소스 서버 수작업 구성
901정성태8/4/201025301Team Foundation Server: 36. TFS 소스 코드 관리 기능 (3) - Label
900정성태8/3/201028068Team Foundation Server: 35. TFS 소스 코드 관리 기능 (2) - Shelveset
899정성태8/2/201029963Team Foundation Server: 34. TFS 소스 코드 관리 기능 (1) - Changeset
... [166]  167  168  169  170  171  172  173  174  175  176  177  178  179  180  ...