Microsoft MVP성태의 닷넷 이야기
.NET Framework: 143. WPF - Transform의 역변환 [링크 복사], [링크+제목 복사],
조회: 24671
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 76  77  78  79  80  81  82  83  84  85  86  87  88  [89]  90  ...
NoWriterDateCnt.TitleFile(s)
11710정성태10/2/201822048.NET Framework: 794. C# - 같은 모양, 다른 값의 한글 자음을 비교하는 호환 분해 [5]
11709정성태9/30/201820371개발 환경 구성: 402. .NET Core 콘솔 응용 프로그램을 docker로 실행/디버깅하는 방법 [1]
11708정성태9/30/201822529개발 환경 구성: 401. .NET Core 콘솔 응용 프로그램을 배포(publish) 시 docker image 자동 생성 [2]파일 다운로드1
11707정성태9/30/201823886오류 유형: 489. ASP.NET Core를 docker에서 실행 시 "Failed with a critical error." 오류 발생 [1]
11706정성태9/29/201820038개발 환경 구성: 400. Synology NAS(DS216+II)에서 실행한 gcc의 Segmentation fault [2]
11705정성태9/29/201820879개발 환경 구성: 399. Synology NAS(DS216+II)에 gcc 컴파일러 설치
11704정성태9/29/201824909기타: 73. Synology NAS 신호음(beep) 끄기 [1]파일 다운로드1
11703정성태9/27/201819660개발 환경 구성: 398. Blazor 환경 구성 후 빌드 속도가 너무 느리다면? [2]
11702정성태9/26/201816874사물인터넷: 44. 넷두이노(Netduino)의 네트워크 설정 방법
11701정성태9/26/201822625개발 환경 구성: 397. 공유기를 일반 허브로 활용하는 방법파일 다운로드1
11700정성태9/21/201820700Graphics: 25. Unity - shader의 직교 투영(Orthographic projection) 행렬(UNITY_MATRIX_P)을 수작업으로 구성
11699정성태9/21/201819174오류 유형: 488. Add-AzureAccount 실행 시 "No subscriptions are associated with the logged in account in Azure Service Management (RDFE)." 오류
11698정성태9/21/201820454오류 유형: 487. 윈도우 성능 데이터를 원격 SQL에 저장하는 경우 "Call to SQLAllocConnect failed with %1." 오류 발생
11697정성태9/20/201819342Graphics: 24. Unity - unity_CameraWorldClipPlanes 내장 변수 의미
11696정성태9/19/201820249.NET Framework: 793. C# - REST API를 이용해 NuGet 저장소 제어파일 다운로드1
11695정성태9/19/201825400Graphics: 23. Unity - shader의 원근 투영(Perspective projection) 행렬(UNITY_MATRIX_P)을 수작업으로 구성
11694정성태9/17/201819626오류 유형: 486. nuget push 호출 시 405 Method Not Allowed 오류 발생
11693정성태9/16/201822798VS.NET IDE: 128. Unity - shader 코드 디버깅 방법
11692정성태9/13/201823098Graphics: 22. Unity - shader의 Camera matrix(UNITY_MATRIX_V)를 수작업으로 구성
11691정성태9/13/201820043VS.NET IDE: 127. Visual C++ / x64 환경에서 inline-assembly를 매크로 어셈블리로 대체하는 방법 - 두 번째 이야기
11690정성태9/13/201823023사물인터넷: 43. 555 타이머의 단안정 모드파일 다운로드1
11689정성태9/13/201822314VS.NET IDE: 126. 디컴파일된 소스에 탐색을 사용하도록 설정(Enable navigation to decompiled sources)
11688정성태9/11/201817668오류 유형: 485. iisreset - The data is invalid. (2147942413, 8007000d) 오류 발생
11687정성태9/11/201819529사물인터넷: 42. 사물인터넷 - 트랜지스터 다중 전압 테스트파일 다운로드1
11686정성태9/8/201818578사물인터넷: 41. 다중 전원의 소스를 가진 회로파일 다운로드1
11685정성태9/6/201818544사물인터넷: 40. 이어폰 소리를 capacitor로 필터링파일 다운로드1
... 76  77  78  79  80  81  82  83  84  85  86  87  88  [89]  90  ...