Microsoft MVP성태의 닷넷 이야기
안녕하세요. SnapsToDevicePixels 질문입니다. [링크 복사], [링크+제목 복사],
조회: 14485
글쓴 사람
이성환 (vactorman at naver.com)
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)

안녕하세요. 오랜만에 질문 드립니다.

WPF로 격자 무늬를 만들려고 Canvas 위에 가로축 세로축으로 Line을 그려서 올렸습니다.

그리고 Line을 원하는 만큼 가늘게 만들면서도 선명한 색상으로 보이게 하려고
(StrokeThickness는 1 이하로)

SnapsToDevicePixels = true 속성을 주었습니다.

그런데 첨부한 예제처럼 Line에 SnapsToDevicePixels = true 로 처리를 하면

모든 Line 에 적용되는 것이 아니라 일부 Line에만 적용됩니다. (SnapsToDevicePixels 값은 모두 true 로 잘 할당되어 있습니다.)

적용된다는 것의 의미는 색상과 StrokeThickness 까지 모두 의도된 것으로 표시된다는 것을 말하는 건데요.

실제로는 모든 Line의 StrokeThickness는 적용된 듯 보이나 일부 Line 들의 색상만 정확히 표시되는 현상이 있습니다

예제에서는 Line 별로 생성할 때 SnapsToDevicePixels = true 처리를 해주었는데

테스트 해본 결과 Canvas나 Grid, Window 에 SnapsToDevicePixels = true 속성을 주어도 결과가 마찬가지였습니다.
(UseLayoutRounding 은 동작이 다르더군요. 제가 의도한 대로 동작하는 것은 SnapsToDevicePixels 이 더 가까웠습니다.)

더군다나 더 특이한 점은

Window의 SizeChanged 에서 실제 Canvas의 크기에 맞춰서 다시 그려주는 코드가 실행되면

색상 처리가 제멋대로 움직여버립니다.


뭔가 제가 속성들의 의미를 잘못 알고 사용한 걸까요?

며칠 동안 검색하고 삽질하면서 같은 자리만 반복하고 있네요.

이게 무슨 현상인지 감이 잡히지도 않습니다.


바쁘신데 죄송스럽지만 도움 부탁드립니다. (__)



[연관 글]






[최초 등록일: ]
[최종 수정일: 11/11/2016]


비밀번호

댓글 작성자
 



2016-11-11 05시09분
재미있군요. Canvas의 SetLeft/Top과 같은 류의 메서드를 쓰면 blur 효과가 나옵니다. 다음과 같이 Line의 X1/X2/Y1/Y2에 직접 설정해 보세요.

        private void DrawHorizonatalLine(int count)
        {
            for (var i = 0; i < count; i++)
            {
                var newLine = new Line();
                newLine.X1 = 0;
                newLine.X2 = this.xCanvas.ActualWidth;

                newLine.Y1 = (int)(i * (this.xCanvas.ActualHeight / count));
                newLine.Y2 = newLine.Y1;

                newLine.SnapsToDevicePixels = true;
                newLine.Stroke = Brushes.Black;
                newLine.StrokeThickness = 1;

                this._horizontalLines.Add(newLine);
                this.xCanvas.Children.Add(newLine);
            }
        }
정성태
2016-11-12 03시27분
[이성환] 답변 감사드립니다.

말씀주신대로 X1,X2,Y1,Y2 값을 조정해 테스트를 해봤는데

색상이 불규칙하게 튀는 증상은 없어졌지만

StrokeThickness 의 값이 1 미만 일 경우 색상(Stroke)이 옅어지는 현상은 그대로 있습니다. (이런 것도 일종의 blur 라고 할 수 있겠네요)

완전히 Black 인 FF000000 인 값을 Stroke에 할당했지만 눈으로 봐도 훨씬 옅어진 것이 보이고

실제 색상 추출툴을 사용해 보면 FF000000 이 아닌 다른 값이 측정되고 있습니다.

snoop 으로 해당 Line 들을 체크해보아도 Stroke에는 FF000000가 할당되어 있지만 실제 화면에는 더 옅은 색상으로 표시됩니다.

그리고 실제 표시되는 Line 픽셀을 확인해보면 StrokeThickness가 1일 때와 1 미만 일 때의 차이가 없는 것으로 보입니다.

StrokeThickness 의 값이 1 이상일 경우에는 Canvas.Set 류의 메서드를 사용해도 색상과 굵기가 정상적으로 적용되는 반면

1 미만의 소수점 값을 할당하면 X1,X2,Y1,Y2 값을 조정해도 위 증상은 여전히 있습니다.

그래서 드는 의문은 SnapsToDevicePixels = true 을 주었을 때 실제 화면에 표시되는 최소 단위가 1 pixel 이 아닌가 하는 것입니다.

그리고 그 이하의 값은 1 pixel 안에서 Stroke가 옅어지는 형태로 처리되는 거 같다는 느낌을 받았습니다.
(SnapsToDevicePixels = false 이면 StrokeThickness 가 1 이라도 blur 가 발생하고 1 미만의 경우는 동일하게 옅어지는 현상이 있습니다.)

SnapsToDevicePixels 라는 이름이 그러한 의미를 지니고 있는 것 같기도 한데

그렇다면 1 미만의 굵기로는 Line을 그릴 수 없다는 얘기가 되는 게 아닌가 싶기도 합니다.

이걸 그냥 안 된다고 하고 끝내야할 문제인지 아니면 다른 방법이 있을 지 고민이 됩니다.
[guest]
2016-11-12 03시40분
WPF/Silverlight 의 그래픽 단위와 Anti-aliasing 처리를 이해하자
; http://www.sysnet.pe.kr/2/0/1281

우선, 위의 글을 읽어보세요.

모니터는 물리적으로 1pixel만을 그릴 수 있는데, StrokeThickness에 0.2를 지정하면 당연히 연하게 처리하게 됩니다.
정성태
2016-11-12 04시22분
[이성환] 답변 감사합니다.

성태님의 글을 읽은적이 있는데 그 땐 '아.. 그렇구나' 하고 넘어가버리고 말았는데

지금 다시 읽어보니 제대로 와닿네요.

대략 방향을 정할 수 있을 거 같습니다.

주말 아침부터 귀찮게 해드린 거 같아 죄송스럽네요.

도움 감사드립니다. (__)
[guest]
2016-11-13 01시31분
아래의 글로 정리해봤습니다. 그런데, 별로 희망적이지가 않군요. ^^;

WPF - Line 요소를 Canvas에 위치시켰을 때 흐림(blur) 현상
; http://www.sysnet.pe.kr/2/0/11108
정성태

... [76]  77  78  79  80  81  82  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
588이성진2/24/200710837웹 -> 스마트클라이언트 -> 웹서비스 의 세션 공유 방법 ? [1]
583김영민2/22/20079306Vista에서 "관리자 권한으로 실행"을 통해 실행한 프로세스의 동작
584정성태2/22/200710707    답변글 [답변]: Vista에서 "관리자 권한으로 실행"을 통해 실행한 프로세스의 동작
582한귀순2/22/20079385sqlhelper 의 updatedataset
585정성태2/23/20078677    답변글 [답변]: sqlhelper 의 updatedataset [1]
579futu...2/16/200710140VS2005의 스마트 클라이언트에서 웹브라우저 예제 질문입니다. [1]
578정해봉2/16/20079358IE Embeded Assambly 방식에서 CAS 설정 방법 [1]
575박성민2/12/20079891COM에 데이터 보내기 질문입니다. [1]
571엔틱스2/7/200710598그냥... 질문은 아닙니다만... [2]
5682/6/20078032이런 오류 화면을 어떻게 찾아봐야 - 알아봐야 - 하는지요?파일 다운로드1
569정성태2/6/20079177    답변글 [답변]: 이런 오류 화면을 어떻게 찾아봐야 - 알아봐야 - 하는지요? [1]
570정성태2/6/20079253        답변글 [답변]: [답변]: 이런 오류 화면을 어떻게 찾아봐야 - 알아봐야 - 하는지요?
5732/8/20078163            답변글 [답변]: [답변]: [답변]: 이런 오류 화면을 어떻게 찾아봐야 - 알아봐야 - 하는지요? [1]파일 다운로드1
565한귀순2/5/20078824typed dataset 의 유용성
566정성태2/6/200710428    답변글 [답변]: typed dataset의 유용성 [1]
564정민영2/5/20078976혹시 이런 경우 보신적 있으신가 궁금합니다..^^; [2]
563창민이2/2/20079124Visual C++ COM Objects Returning Recordsets 사용에 대해.. [3]
562현석1/29/20078985C# 스마트응용장치에서 아이콘 움직이게하는거 질문요 ^^ [1]파일 다운로드1
559초보1/27/200710355급 질문 입니다. visual studio 자동 종료에 대한 질문입니다. [2]
558즈믄1/26/200710297.Net Framework v2.0에서 Winform의 Panel에 Excel파일 보여주기 [2]
556정재우1/26/200710027vista에서 smartclient의 System.Security.PermissionsRegistryPermission 에러 [1]
555dev....1/25/2007117132005 WebBrowser내에서 팝업 처리 문제 관련 질문입니다.
561정성태1/29/200714607    답변글 [답변]: 2005 WebBrowser 내에서 팝업 처리 문제 관련 질문입니다.
554sky1/23/20079967<급질문> interop 를 사용함에 있어 [2]
557sky1/26/20078349    답변글 [답변]: <급질문> interop 를 사용함에 있어
553deve...1/15/200710303오류가 나는데 도저히 모르겠네여...좀 봐주세요... [3]파일 다운로드1
... [76]  77  78  79  80  81  82  83  84  85  86  87  88  89  90  ...