Microsoft MVP성태의 닷넷 이야기
안녕하세요. SnapsToDevicePixels 질문입니다. [링크 복사], [링크+제목 복사],
조회: 21158
글쓴 사람
이성환 (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
정성태

... [91]  92  93  94  95  96  97 
NoWriterDateCnt.TitleFile(s)
183정성태5/9/20059446    답변글 [답변]: // 꼭쫌 답변해 주세요~~~클라이언트 서버 ... 내용, 이점 들...
180최성우5/7/20059906[Q] POST 형식의 데이터 훅킹?
182정성태5/9/200510533    답변글 [답변]: [Q] POST 형식의 데이터 훅킹?
190최성우5/10/20059565        답변글 [답변]: [답변]: [Q] POST 형식의 데이터 훅킹?
177최정희5/4/200510097네트워크 케이블의 연결상태
178정성태5/4/200510213    답변글 [답변]: 네트워크 케이블의 연결상태 [1]
188최정희5/10/20059678        답변글 [답변]: [답변]: 네트워크 케이블의 연결상태
189정성태5/10/20059880            답변글 [답변]: [답변]: [답변]: 네트워크 케이블의 연결상태 [2]
191최정희5/11/20059518                답변글 [답변]: [답변]: [답변]: [답변]: 네트워크 케이블의 연결상태 [1]
175안연준5/3/20059912IE 제어에 대한 궁금 증 ㅡ,.ㅡ;;
179정성태5/4/200510575    답변글 [답변]: IE 제어에 대한 궁금 증 ㅡ,.ㅡ;;
168안연준5/2/20059959[Database] Connection Error파일 다운로드1
169정성태5/2/200510100    답변글 [답변]: [Database] Connection Error
170안연준5/2/20059650        답변글 [답변]: [답변]: 계속 에러가 똑같애요
171정성태5/2/200510372            답변글 [답변]: [답변]: [답변]: 계속 에러가 똑같애요
172안연준5/2/200510147                답변글 [답변]: [답변]: [답변]: [답변]: 계속 에러가 똑같애요파일 다운로드1
173정성태5/2/20059902                    답변글 [답변]: [답변]: [답변]: [답변]: [답변]: 계속 에러가 똑같애요
174안연준5/3/20059867                        답변글 [답변]: [답변]: [답변]: [답변]: [답변]: [답변]: 계속 에러가 똑같애요
165장희석4/22/200510488[질문]ASP에서 ATL 서버 컴퍼넌트로 바이너리 데이타 전달하기
167정성태4/29/200510313    답변글 [답변]: [질문]ASP에서 ATL 서버 컴퍼넌트로 바이너리 데이타 전달하기
160카심4/21/20059894Internet Explorer 에서의 닷넷 Smart Client 개발
163정성태4/22/20059827    답변글 [답변]: Internet Explorer 에서의 닷넷 Smart Client 개발
159신대철4/21/20059621자동 로긴 프로그램
162정성태4/22/20059626    답변글 [답변]: 자동 로긴 프로그램
166신대철4/22/20059306        답변글 [답변]: [답변]: 자동 로긴 프로그램파일 다운로드1
157이용휘4/20/20059307w3ip를 통해서 윈도우 미디어 화을을 올려놓을 서버..
... [91]  92  93  94  95  96  97