{"id":14123031,"url":"https://github.com/JamesnetGroup/riotplaybutton","last_synced_at":"2025-08-03T06:32:54.115Z","repository":{"id":262188740,"uuid":"719614131","full_name":"JamesnetGroup/riotplaybutton","owner":"JamesnetGroup","description":null,"archived":false,"fork":false,"pushed_at":"2024-11-11T03:47:39.000Z","size":13772,"stargazers_count":30,"open_issues_count":0,"forks_count":5,"subscribers_count":1,"default_branch":"main","last_synced_at":"2024-11-26T23:36:35.037Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"C#","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/JamesnetGroup.png","metadata":{"files":{"readme":"README.ko.md","changelog":null,"contributing":null,"funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null},"funding":{"github":["vickyqu115"]}},"created_at":"2023-11-16T14:39:24.000Z","updated_at":"2024-11-11T14:20:16.000Z","dependencies_parsed_at":"2024-11-11T04:33:10.605Z","dependency_job_id":null,"html_url":"https://github.com/JamesnetGroup/riotplaybutton","commit_stats":null,"previous_names":["jamesnetgroup/riotplaybutton"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JamesnetGroup%2Friotplaybutton","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JamesnetGroup%2Friotplaybutton/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JamesnetGroup%2Friotplaybutton/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/JamesnetGroup%2Friotplaybutton/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/JamesnetGroup","download_url":"https://codeload.github.com/JamesnetGroup/riotplaybutton/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":228533693,"owners_count":17933243,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-08-15T08:00:35.618Z","updated_at":"2024-12-06T22:30:39.046Z","avatar_url":"https://github.com/JamesnetGroup.png","language":"C#","funding_links":["https://github.com/sponsors/vickyqu115"],"categories":["WPF 튜토리얼 시리즈"],"sub_categories":["2. Riot Play Button"],"readme":"# RiotPlayButton [![English](https://img.shields.io/badge/Language-English-blue.svg)](README.md) [![中文](https://img.shields.io/badge/Language-中文-red.svg)](README.zh-CN.md) [![한국어](https://img.shields.io/badge/Language-한국어-green.svg)](README.ko.md)\n\n리그 오브 레전드의 PLAY 버튼에서 영감을 받은 사용자 정의 WPF ToggleButton 기반 컨트롤\n\n[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)\n[![.NET](https://img.shields.io/badge/.NET-8.0-blue.svg)](https://dotnet.microsoft.com/download)\n[![Stars](https://img.shields.io/github/stars/vickyqu115/riotplaybutton.svg)](https://github.com/vickyqu115/riotplaybutton/stargazers)\n[![Issues](https://img.shields.io/github/issues/vickyqu115/riotplaybutton.svg)](https://github.com/vickyqu115/riotplaybutton/issues)\n\n## 프로젝트 개요\n\nRiotPlayButton은 리그 오브 레전드 게임 클라이언트의 PLAY 버튼을 재현한 사용자 정의 WPF 컨트롤입니다. 사용자 정의 형태 생성, 그라데이션 브러시, 애니메이션, 효율적인 XAML 디자인 등 고급 WPF 기술을 보여줍니다.\n\n\u003cimg src=\"https://github.com/user-attachments/assets/cc980d89-4479-4c4d-8d6a-d97593e12b3b\" width=\"49%\"/\u003e\n\u003cimg src=\"https://github.com/user-attachments/assets/033e7a46-c0d2-4f3c-9566-69ec0028f442\" width=\"49%\"/\u003e\n\u003cimg src=\"https://github.com/user-attachments/assets/ea15edee-6efd-43c5-b796-226ccb78e89a\" width=\"49%\"/\u003e\n\u003cimg src=\"https://github.com/user-attachments/assets/4beb7730-cfd5-46fb-9a5e-31075ae0db2d\" width=\"49%\"/\u003e\n\u003cimg src=\"https://github.com/user-attachments/assets/7d0f803c-c8f7-40e0-a324-7ecc4b75126a\" width=\"49%\"/\u003e\n\u003cimg src=\"https://github.com/user-attachments/assets/218fe98c-dfa8-4eb0-9038-c8f4199f107b\" width=\"49%\"/\u003e\n\n## 주요 기능 및 구현 사항\n#### 1. 사용자 정의 WPF 컨트롤 개발\n- [x] 특수 기능을 위한 WPF ToggleButton 확장\n- [x] 순수 XAML을 사용한 복잡한 UI 요소 구현\n\n#### 2. 고급 XAML 기술\n- [x] Path와 Geometry를 사용한 불규칙한 형태 생성\n- [x] 정교한 색상 효과를 위한 LinearGradientBrush 활용\n\n#### 3. 복잡한 형태 생성\n- [x] 다중 포인트 형태 생성을 위한 Polygon 사용\n- [x] 부드럽고 복잡한 곡선을 위한 Cubic Bezier 곡선 구현\n- [x] 간단한 곡선 형태를 위한 Quadratic Bezier 곡선 적용\n\n#### 4. 애니메이션 및 상호작용\n- [x] Jamesnet.WPF Nuget 패키지를 사용한 부드러운 애니메이션\n- [x] 마우스 오버 및 체크 상태에 대한 상호작용 효과\n\n#### 5. 성능 최적화\n- [x] 클리핑 기술을 사용한 효율적인 렌더링\n- [x] 성능 향상을 위한 최적화된 XAML 구조\n\n#### 6. 충실한 재현\n- [x] 리그 오브 레전드 PLAY 버튼의 픽셀 퍼펙트 재현\n- [x] 디자인과 기능성에 대한 세심한 주의\n\n\u003cimg src=\"https://github.com/user-attachments/assets/0abeddcb-8f4e-4273-82d8-e7c42849ec4e\" width=\"49%\"/\u003e\n\u003cimg src=\"https://github.com/user-attachments/assets/4feb4e87-dbc2-435a-b5fb-cff1640004f8\" width=\"49%\"/\u003e\n\u003cimg src=\"https://github.com/user-attachments/assets/f7f97dca-9918-45bc-aa49-5920059728ae\" width=\"49%\"/\u003e\n\u003cimg src=\"https://github.com/user-attachments/assets/7181da5b-0218-40a7-b1a6-e9ac05b334bf\" width=\"49%\"/\u003e\n\u003cimg src=\"https://github.com/user-attachments/assets/a3a52292-c9ac-441f-bf5c-9f3dd40823e5\" width=\"49%\"/\u003e\n\u003cimg src=\"https://github.com/user-attachments/assets/c777c08a-9680-4b6c-97e8-1a1edc5d6fb5\" width=\"49%\"/\u003e\n\n## 기술 스택\n- WPF (Windows Presentation Foundation)\n- .NET 8.0\n- C#\n- Jamesnet.WPF Nuget 패키지\n\n## 시작하기\n### 필요 조건\n- Visual Studio 2022 이상\n- .NET 8.0 SDK\n\n### 설치 및 실행\n#### 1. 리포지토리 복제:\n\n```\ngit clone https://github.com/vickyqu115/riotplaybutton.git\n```\n\n#### 2. 솔루션 열기\n- [x] Visual Studio\n- [x] Visual Studio Code\n- [x] JetBrains Rider\n\n\u003cimg src=\"https://github.com/user-attachments/assets/af70f422-7057-4e77-a54d-042ee8358d2a\" width=\"32%\"/\u003e\n\u003cimg src=\"https://github.com/user-attachments/assets/e4feaa10-a107-4b58-8d13-1d8be620ec62\" width=\"32%\"/\u003e\n\u003cimg src=\"https://github.com/user-attachments/assets/5ff487f6-55e4-43e1-9abf-f8d419ee6943\" width=\"32%\"/\u003e\n\n#### 3. 빌드 및 실행\n- [x] 시작 프로젝트 설정\n- [x] F5를 누르거나 실행 버튼 클릭\n- [x] Windows 11 권장\n\n## 학습 자료\n- [구현에 대한 상세 아티클 (jamesnet.dev)](https://jamesnet.dev/article/51)\n- [YouTube 튜토리얼 (영어, 한글자막)](https://bit.ly/40YoVIo)\n- [BiliBili 튜토리얼 (중국어)](https://bit.ly/49L6dXu)\n\n## 기여하기\nRiotPlayButton에 대한 기여를 환영합니다! 이슈를 제출하거나, 풀 리퀘스트를 생성하거나, 개선 사항을 제안해 주세요.\n\n## 라이선스\n이 프로젝트는 MIT 라이선스 하에 배포됩니다. 자세한 내용은 [LICENSE](LICENSE) 파일을 참조하세요.\n\n## 연락처\n- 웹사이트: https://jamesnet.dev\n- 이메일: vickyqu115@hotmail.com, james@jamesnet.dev\n\n고급 형태 생성 기술을 갖춘 이 매력적인 리그 오브 레전드 스타일의 PLAY 버튼으로 WPF 애플리케이션을 향상시켜 보세요!\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FJamesnetGroup%2Friotplaybutton","html_url":"https://awesome.ecosyste.ms/projects/github.com%2FJamesnetGroup%2Friotplaybutton","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FJamesnetGroup%2Friotplaybutton/lists"}