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

... 31  [32]  33  34  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
5072엔벌잉10/24/20188015C# textbox, button질문입니다! [4]파일 다운로드1
5071엔벌잉10/23/20188392C#윈도우폼 질문입니다!! [2]
5070진우10/17/20188329Visual Studio 서비스팩과 업데이트 차이 문의 [2]
5069감자10/12/20189072빌드 구성을 재설정하는 방법이 있을까요? [1]파일 다운로드1
5068누오10/10/20187844ASP Core 2.0 에서 dll안에 있는 뷰 읽어들이는 방법? [1]
5067김정민10/5/20187845다른 윈도우가 깨지는 현상을 막을 수 있을까요 [3]
5066로니브10/4/20188628ASP.NET MVC에서 View 파일 숨기는법? 보안처리 하는법? 관련 질문.. [1]
5065키모10/1/20189828문자 질문입니다. [3]
5064로니브10/1/20189167클래스 라이브러리에서 .cshtml파일을 추가하는 방법은 없나요? [3]
5063진우9/28/20188197ADO.net 과 Entity Framework 차이 문의 [2]
5062테스트9/27/20188720C# import file 의 구조체 배열 선언 및 호출에 대해 문의. [3]
5061안녕하세요9/13/20188705c# 프로그래밍 관련 문의 [1]
5060임민재9/8/20188205c# install 파일 생성 시 문제가 발생하였습니다 [1]파일 다운로드1
50599/7/20187869Winform TextBox 포커스 유지하는 방법 질문 [파일첨부] [1]파일 다운로드1
50589/5/201811280Winform TextBox 포커스 유지하는 방법 질문 [3]
5056박종윤8/30/201810619c# dll을 C++에서 사용 시 event 호출 [4]파일 다운로드1
5055초보자8/29/20189254asp.net 에서 다른 서버의 iis를 stop하는 batch file을 실행시키는데 동작하지 않습니다. [5]
5054사도신8/29/20187956[wpf] textbox insert overite 모드시에 [4]파일 다운로드1
5053엿장수8/26/20187322directshow filter 에서의 IMediaSample 의 시간에대한질문입니다 [1]
5052오명현8/26/20188208Tcp소켓 실습 Exeption 도와주세요! [4]파일 다운로드1
5049오명현8/23/20187581책 477페이지 내용 중 이해가 안가는 부분이 있어 질문드립니다. [1]
5048오명현8/23/20187270포트 관련 질문 하나더 있습니다. [1]
5047오명현8/22/20187941포트가 없을 경우를 가정한 내용에 대해 질문이 있습니다. 책468p. [1]
5046엿장수8/22/20187819다이렉트쇼 필터 추가하는데 [2]
5045임도진8/22/20188541c# opencv dll파일 로드 질문 [3]파일 다운로드1
5044엿장수8/20/20188238graphedit 에 등록되어있는 필터를 가져와서 사용하는방법을 알고싶습니다 [2]
... 31  [32]  33  34  35  36  37  38  39  40  41  42  43  44  45  ...