Microsoft MVP성태의 닷넷 이야기
Math: 10. C# - (타)원 영역의 마우스 클릭 판단 [링크 복사], [링크+제목 복사],
조회: 30495
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일

C# - (타)원 영역의 마우스 클릭 판단


아래와 같은 질문이 있어서 적어봅니다. ^^

동그란 형태의 영역 체크하기
; http://social.msdn.microsoft.com/Forums/ko-KR/visualcplusko/thread/ea521d3c-93ba-498f-860f-6fc689c1151d

우선, Win32 API로 CreateEllipticRgn, PtInRegion이 있기 때문에,

CreateEllipticRgn function 
; https://docs.microsoft.com/en-us/windows/win32/api/wingdi/nf-wingdi-createellipticrgn
 
그리고, 영역 체크 역시 마찬가지입니다. 

PtInRegion function 
; https://docs.microsoft.com/en-us/windows/win32/api/wingdi/nf-wingdi-ptinregion

C#에서도 쉽게 DllImport 기능을 이용하여 사용할 수 있습니다.




그래도, 가끔은 원리를 아는 것이 중요할 때가 있지요. ^^ (가령, Javascript에서라면 Win32 API를 호출할 수 없기 때문에.)

우선, 원의 내부에서 마우스 클릭이 된 것인지 판단하는 것은 어렵지 않습니다.

아래 그림에서처럼,

mouse_click_in_ellipse_1.png

피타고라스 정리를 이용해서 c2 = a2 + b2을 하게 되면 c의 길이를 구할 수 있고, 그 값이 반지름 r보다 작으면 원 안에 있다고 판단할 수 있습니다.

문제는 타원인데요. 이것은 타원에 대한 지식을 요구합니다.

타원 방정식
; http://yhsmc.com.ne.kr/Math/sunengdaebi/math2/sub3-8.pdf

타원은 "평면 위에서 두 정점에서의 거리의 합이 일정한 점 전체의 집합"이라고 정의되었는데요.

mouse_click_in_ellipse_2.png

위의 그림에서 "두 정점"은 (-c, 0), (c, 0)을 의미하고, "거리의 합"은 2r, 즉 '장축'의 길이에 해당합니다. 따라서, 타원은 (-c, 0), (c, 0)을 잇는 선 a, b의 길이의 합이 2r인 '점 전체의 집합'이 됩니다.

여기서, 좌표 c는 무작위 값이 아니고 다음의 공식에 해당하는 좌표입니다.

c2 = a2 - b2

그럼, 기본적인 값은 모두 알아봤으니 이제 타원 내에 마우스가 위치해 있는 조건을 구할 수 있습니다. (위의 설명은 '장축 = x축, 단축 = y축'인 타원을 그렸을 때 해당하고, 그 반대의 경우라면 타원의 공식이 달라지기 때문에 그에 맞게 변경해 주어야 합니다.)

  1. 마우스 위치에 따른 b, a 길이는 피타고라스 정리에 의해서 구할 수 있고,
  2. b + a < 2r인 경우 타원 안에 있다고 판정.

첨부된 파일을 실행하면 다음과 같이 마우스 위치에 따라 "윈도우 타이틀" 속성에 True/False를 나타내는 예제가 동작합니다.

mouse_click_in_ellipse_3.png

참고로, 예제 코드는 x, y의 장/단축이 바뀐 경우까지 반영되었습니다.




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







[최초 등록일: ]
[최종 수정일: 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)
11970정성태7/2/201920230오류 유형: 552. 웹 브라우저에서 파일 다운로드 후 "Running security scan"이 끝나지 않는 문제
11969정성태7/2/201920767Math: 63. C# - 3층 구조의 신경망파일 다운로드1
11968정성태7/1/201927463오류 유형: 551. Visual Studio Code에서 Remote-SSH 연결 시 "Opening Remote..." 단계에서 진행되지 않는 문제 [1]
11967정성태7/1/201921575개발 환경 구성: 446. Synology NAS를 Windows 10에서 iSCSI로 연결하는 방법
11966정성태6/30/201920438Math: 62. 활성화 함수에 따른 뉴런의 출력을 그리드 맵으로 시각화파일 다운로드1
11965정성태6/30/201921030.NET Framework: 846. C# - 2차원 배열을 1차원 배열로 나열하는 확장 메서드파일 다운로드1
11964정성태6/30/201922107Linux: 20. C# - Linux에서의 Named Pipe를 이용한 통신
11963정성태6/29/201921783Linux: 19. C# - .NET Core Unix Domain Socket 사용 예제
11962정성태6/27/201919330Math: 61. C# - 로지스틱 회귀를 이용한 선형분리 불가능 문제의 분류파일 다운로드1
11961정성태6/27/201919510Graphics: 37. C# - PLplot - 출력 모음(Family File Output)
11960정성태6/27/201920572Graphics: 36. C# - PLplot의 16색 이상을 표현하는 방법과 subpage를 이용한 그리드 맵 표현
11959정성태6/27/201921656Graphics: 35. matplotlib와 PLplot의 한글 처리
11958정성태6/25/201926177Linux: 18. C# - .NET Core Console로 리눅스 daemon 프로그램 만드는 방법 [6]
11957정성태6/24/201923880Windows: 160. WMI 쿼리를 명령행에서 간단하게 수행하는 wmic.exe [2]
11956정성태6/24/201923116Linux: 17. CentOS 7에서 .NET Core Web App 실행 환경 구성 [1]
11955정성태6/20/201921187Math: 60. C# - 로지스틱 회귀를 이용한 분류파일 다운로드1
11954정성태6/20/201919508오류 유형: 550. scp - sudo: no tty present and no askpass program specified
11953정성태6/20/201917504오류 유형: 549. The library 'libhostpolicy.so' required to execute the application was not found in '...'
11952정성태6/20/201918553Linux: 16. 우분투, Centos의 Netbios 호스트 이름 풀이 방법
11951정성태6/20/201921714오류 유형: 548. scp 연결 시 "Permission denied" 오류 및 "WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!" 경고
11950정성태6/18/201922564.NET Framework: 845. C# - 윈도우 작업 관리자와 리소스 모니터의 메모리 값을 구하는 방법
11949정성태6/18/201917717오류 유형: 547. CoreCLR Profiler 예제 프로젝트 빌드 시 컴파일 오류 유형
11948정성태6/17/201919627Linux: 15. 리눅스 환경의 Visual Studio Code에서 TFS 서버 연동
11947정성태6/17/201922083Linux: 14. 리눅스 환경에서 TFS 서버 연동
11946정성태6/17/201922966개발 환경 구성: 445. C# - MathNet으로 정규 분포를 따르는 데이터를 생성, PLplot으로 Histogram 표현파일 다운로드1
11945정성태6/17/201920566Linux: 13. node.js에서 syslog로 출력하는 방법
... 76  77  78  79  [80]  81  82  83  84  85  86  87  88  89  90  ...