- English | pусский | украинец
+ English | 中文 | Русский | 日本語 | Українська | 한국어
+ Attention: readme files are maintained by translators and may become outdated from time to time. For newest info rely on English version.
+ English | 中文 | Русский | 日本語 | Українська | 한국어
+ 주의: readme 파일들은 번역자들에 의해 업데이트되며 시간이 지나면 최신 내용이 아니게 될 수 있습니다. 새로운 기능은 가장 먼저 영어 버전에 기재됩니다.
+
+ 주요 기능 • + 다운로드 • + 동작 방식 • + 기여 • + 로드맵 • + 제작자 • + 라이선스 +
-(다운로드는 [release tab](https://github.com/thepbone/galaxybudsclient/releases)에서 가능합니다.) -이 프로그램은 Buds가 정보(설정)를 송/수신할 때 사용하는 커스텀 RFComm 시리얼 프로토콜 연구의 결과물 중 하나입니다. 만약 프로토콜의 구조나 시리얼 통신의 내용에 대해 궁금하시다면, 리버스 엔지니어링을 했던 모든 내용을 기록한 제 노트를 확인하세요: +## 주요 기능 -* [My Buds (2019) Notes](GalaxyBudsRFCommProtocol.md) -* [My Buds Plus Notes](Galaxy%20Buds%20Plus%20RFComm%20Protocol%20Notes.md) +데스크탑에서 삼성 갤럭시 버즈 디바이스의 설정 및 제어가 가능합니다. -## 기능 +알려진 공식 안드로이드 앱의 기본 기능과 별도로, 이 프로젝트는 이어버즈의 모든 잠재 기능들과 새로운 기능들을 사용할 수 있도록 도와줍니다. 예를 들면: -**새로운 기능** (기존 기능 제외): +* 자세한 배터리 정보 +* 기능 점검과 공장 자체 테스트 +* 숨겨진 디버깅 정보를 로드 +* 사용자 설정이 가능한 길게 누르기 동작 +* 그 이외 다른 기능들... -* 터치패드: 사용자 지정 터치/길게 누르기 동작 (외부 응용 프로그램 실행, 이퀄라이저 켜기/끄기, 주변 소리 듣기 음량 조절, ...)[1] -* 이어버드를 착용했을 시 미디어 재생 재개 -* 배터리 상태를 표시하는 시스템 트레이 -* 대시보드에 자세한 센서 정보를 표시합니다. 다음을 포함합니다: - * 양쪽 이어버드 내부 ADC의 전압 및 전류 (아날로그-디지털 컨버터) - * 양쪽 이어버드의 온도 - * 더 정확한 배터리 용량 (5% 단위 기준 표시를 대체) -* 모든 온보드 컴포넌트에 대해 셀프 테스트 수행 -* 다양한 정보를 표시(디버그), 다음을 포함합니다: - * 하드웨어 리비전 - * (터치) 펌웨어 버전 - * 양쪽 이어버드의 Bluetooth 주소 - * 양쪽 이어버드의 시리얼 번호 - * 펌웨어 빌드 정보 (컴파일 날짜, 개발자 이름) - * 배터리 종류 - * 기타 센서 정보 -* 이퀄라이저: 'Dolby 최적화' 기능 해제 -* 터치패드: 음량 올리기/내리기를 다른 옵션과 통합 [1] +## 다운로드 -> [1] Galaxy Wearable 앱에서 터치패드 설정을 변경할 경우 이 기능은 자동적으로 초기화됩니다. -## 설치 +Windows 바이너리는 [release](https://github.com/ThePBone/GalaxyBudsClient/releases)에서 다운로드가 가능합니다. 설치하기 전에 릴리즈 노트를 읽어 주세요. -**이 프로그램은 [.Net Framework](https://dotnet.microsoft.com/download/dotnet-framework/net461) 4.6.1 이나 그 이상의 버전을 필요로 합니다.** + -[**여기**](https://github.com/ThePBone/GalaxyBudsClient/releases)에서 전체 설치 파일을 다운로드할 수 있습니다. +## 동작 방식 -정품 **Galaxy Buds (2019)** 와 **Galaxy Buds+ (2020)** 에 대해 모든 기능을 지원합니다. +Bluetooth 무선 기술을 사용하기 위해, 디바이스는 동작 가능한 앱과 디바이스가 다른 Bluetooth 디바이스와 통신하는 데 사용하는 일반적인 동작을 정의한 Bluetooth 프로필을 해석할 수 있어야 합니다. -![Downloads](https://img.shields.io/github/downloads/ThePBone/GalaxyBudsClient/total) +갤럭시 버즈는 두 개의 Bluetooth 프로필을 정의합니다: A2DP (Advanced Audio Distribution Profile) 오디오 스트리밍/제어와 바이너리 스트림 통신을 위한 SPP (Serial Port Profile). 제조사들은 설정 데이터를 주고 받고, 펌웨어 업데이트나 기타 명령을 다른 Bluetooth 장치로 전송하기 위해 보통 이 프로필들을 사용하는 경우가 많습니다. -또는, [@superbonaci](https://github.com/superbonaci) 님이 제공하신 [Chocolatey](https://chocolatey.org/courses/getting-started/what-is-chocolatey) 패키지를 사용할 수 있습니다: +A2DP 프로필이 표준화 및 문서화되더라도, RFCOMM 프로토콜로 교환되는 실제 바이너리 데이터의 형식은 일반적으로 문서화되지 않은 독자적 형식입니다. -``` -choco install galaxybudsclient -``` +이 데이터 형식을 역분석하기 위해, 저는 이어버즈로부터 전송되는 바이너리 스트림을 분석하기 시작했습니다. 그 후에는 디바이스들의 내부 동작을 더 자세히 알기 위해 안드로이드 공식 갤럭시 버즈 앱을 분석했습니다. 이 일을 하는 동안, 저는 제가 했던 생각들을 기록했습니다. 별로 아름다운 기록은 아니지만, 밑에 링크를 기재했습니다. 제가 상세한 내용 하나 하나에 대해서 모두 기록하지는 않았음을 알아두세요. 프로토콜에 대해 더 자세한 정보를 알고 싶다면 소스 코드를 확인하세요. -## 번역 ++ 갤럭시 버즈 (2019) 기록 • + 갤럭시 버즈 플러스 기록 +
-* [@PlasticBrain](https://github.com/fhalfkg) - 한국어, 일본어 번역 +갤럭시 버즈 플러스를 유심히 분석하면서, 저는 펌웨어 디버그 모드와 쓰이지 않은 페어링 모드, Bluetooth 키 덤퍼와 같은 특이한 기능을 찾아냈습니다. 그 기능들에 대한 내용도 아래의 링크에 기록했습니다: + + + +현재, 저는 버즈 플러스의 펌웨어를 수정하고 역분석하려고 합니다. 작업 시 펌웨어 바이너리를 가져와 분석할 수 있는 툴이 있습니다. 아래의 링크를 참조하세요: + + ## 기여 -* [@superbonaci](https://github.com/superbonaci) - Chocolatey package -* [@githubcatw](https://github.com/githubcatw) - Connection dialog base +기능 요청, 버그 보고, Pull Requests 등 어떤 형태의 기여도 환영합니다. + +버그를 제보하거나 아이디어를 제시하고 싶으시면, 템플릿과 함께 제공되는 [새로운 Issue 생성](https://github.com/ThePBone/GalaxyBudsClient/issues/new/choose)을 이용해 주세요. [위키](https://github.com/ThePBone/GalaxyBudsClient/wiki/2.-How-to-submit-issues)를 방문해 자세한 설명을 참고하세요. + +이 프로그램의 번역에 도움을 제공하고 싶으시다면, [위키의 설명](https://github.com/ThePBone/GalaxyBudsClient/wiki/3.-How-to-help-with-translations)을 참조하세요. 프로그래밍 지식을 요구하지 않으며, Pull Request 전 어떤 개발 툴의 설치도 없이 번역을 테스트할 수 있습니다. + +소스 코드에 기여하고 싶으시다면, 변경한 내용에 대한 Pull Request를 생성하면 됩니다. 프로그램에 대한 크거나 민감한 기여 사항은 작업을 시작하기 전에 Issue를 생성해 주세요. (또는 텔레그램 [@thepbone](https://t.me/thepbone)으로 연락) + +## 로드맵 + +버전 4.0은 2020년 말에 출시를 계획하고 있으며, 크로스 플랫폼 지원을 포함합니다. 진행 상황은 다음과 같습니다: + + +- [x] .NET Core 3.1로 이전 +- [x] AvaloniaUI.NET로 사용자 인터페이스 포팅 +- [x] Linux: 네이티브 Bluetooth 인터페이스 구현 +- [x] 크로스 플랫폼 Bluetooth 디바이스 선택 알림 +- [X] Windows: 네이티브 Bluetooth 인터페이스 구현 +- [ ] Windows/Linux: 네이티브 트레이 아이콘 지원 (libappindicator) +- [ ] Linux: NVIDIA와 libSkia의 호환 불가능 해결 + +[Milestone v4.0](https://github.com/ThePBone/GalaxyBudsClient/projects/3)을 통해 자세한 정보를 확인할 수 있습니다. +이 로드맵에 대한 기여에 대해서는 매우 감사하게 생각할 것입니다. 새로운 구현 사항은[`avalonia-rewrite`](https://github.com/ThePBone/GalaxyBudsClient/tree/avalonia-rewrite) branch를 참조하세요. -___ +## 제작자 + +#### 기여 + +* [@ArthurWolfhound](https://github.com/ArthurWolfhound) - Issue 템플릿, 위키 제작과 번역 +* [@AndriesK](https://github.com/AndriesK) - 버즈 라이브 버그 픽스 +* [@githubcatw](https://github.com/githubcatw) - 연결 알림 기반 제작 + +#### 번역 + +* [@ArthurWolfhound](https://github.com/ArthurWolfhound) - 러시아어, 우크라이나어 번역 +* [@PlasticBrain](https://github.com/fhalfkg) - 한국어, 일본어 번여 +* [@erenbektas](https://github.com/erenbektas) - 터키어 번역 +* [@kakkk](https://github.com/kakkk) , [@KevinZonda](https://github.com/KevinZonda), [@ssenkrad](https://github.com/ssenkrad) - 중국어 번역 +* [@efrenbg1](https://github.com/efrenbg1), Andrew Gonza - 스페인어 번역 +* [@giovankabisano](https://github.com/giovankabisano) - 마인어 번역 +* [@lucasskluser](https://github.com/lucasskluser) - 포르투갈어 번역 +* [@alb-p](https://github.com/alb-p) - 이탈리아어 번역 +* [@Buashei](https://github.com/Buashei) - 폴란드어 번역 + +## 라이선스 + +이 프로젝트는 [GPLv3](LICENSE) 라이선스를 따릅니다. 삼성과 관련되지 않았으며 그 어떤 권고나 제한도 받지 않습니다. + +``` +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, +INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR +THE USE OR OTHER DEALINGS IN THE SOFTWARE. +``` -Bitcoin: 3EawSB3NfX6JQxKBBFYh6ZwHDWXtJB84Ly diff --git a/README_rus.md b/README_rus.md index 8641f7ea8..94ee3a1f5 100644 --- a/README_rus.md +++ b/README_rus.md @@ -1,72 +1,141 @@ -# Galaxy Buds Client -Неофициальный менеджер для наушников Galaxy Buds (Buds, Buds+, Buds Live) для Windows +
+ English | 中文 | Русский | 日本語 | Українська | 한국어
+ Внимание: файлы "О проекте" поддерживаются переводчиками и могут время от времени не соответствовать текущей версии. Для новейшей информации полагайтесь на англоязычный вариант.
+
+ Основные возможности • + Скачать • + Как это работает • + Внести вклад • + Дорожная карта • + Имена • + Лицензия +
-(Вы можете найти загрузки в разделе [релизов](https://github.com/thepbone/galaxybudsclient/releases)) -Этот клиент является результатом моего исследования специальной версии последовательного протокола RFComm, который Buds используют для получения и отправки двоичных (конфигурационных) данных. Если вас интересует структура протокола и его последовательные сообщения, я рекомендую вам изучить мои заметки, которые я сделал при реверс-инжиниринге: -* [Заметки о Buds (2019), английский](GalaxyBudsRFCommProtocol.md) -* [Заметки о Buds Plus, английский](Galaxy%20Buds%20Plus%20RFComm%20Protocol%20Notes.md) +## Основные возможности -## Функции +Настраивайте и управляйте любым устройством Samsung Galaxy Buds и интегрируйте их в свой компьютер. -**Новые функции** (в дополнение к уже существующим): +Помимо стандартных функций, известных из официального приложения для Android, этот проект поможет вам раскрыть весь потенциал ваших наушников и реализует новые функции, такие как: -* Сенсорная панель: Настраиваемые действия (нажать и задержать) для запуска приложений, управления эквалайзером, управления громкостью звукового фона, ...[1] -* Возобновить воспроизведение если наушники одеты -* Контекстное меню в системном трее со сведениями о заряде батареи -* Отображение расширенных данных сенсоров на главном экране, что включает: - * Вольты и ток на встроенном АЦП (Аналого-цифровой преобразователь) обоих наушников - * Температура обоих наушников - * Более точный статус заряда (вместо шагов в 5 процентов) -* Выполнение самодиагностики всех компонентов на борту -* Отображение различной (отладочной) информации, включая: - * Аппаратная версия - * (Сенсорная панель) Версия прошивки - * Адреса Bluetooth обоих наушников - * Серйиные номера обоих наушников - * Информация о сборке (Дата компиляции, Имя сборщика) - * Тип батареи - * Данные других сенсоров -* Сенсорная панель: Комбинируйте управление громкостью с другими действиями[1] -* Эквалайзер: разблокируйте функцию 'Оптимизировать для Dolby'[2] +* Подробная статистика батареи +* Диагностика и заводское самотестирование +* Множество скрытой отладочной информации +* Настраиваемые действия удержания сенсорной панели +* и многое другое... -> [1] Учтите что приложение Wearable автоматически сбросит настройки этих функций при открытии настроек Сенсорной панели на телефоне -> -> [2] Только для Buds (2019) +## Скачать -## Установка +Загрузите файлы для Windows в разделе [релизы](https://github.com/ThePBone/GalaxyBudsClient/releases). Пожалуйста, прочтите примечания к релизу перед установкой. -Вы можете [**загрузить**](https://github.com/ThePBone/GalaxyBudsClient/releases) полностью автоматический установочный пакет в [**разделе релизов**](https://github.com/ThePBone/GalaxyBudsClient/releases) этого репозитория! + -*Эта программа требует [.Net Framework](https://dotnet.microsoft.com/download/dotnet-framework/net461) 4.6.1 или новее* +## Как это работает -![Downloads](https://img.shields.io/github/downloads/ThePBone/GalaxyBudsClient/total) +Чтобы использовать беспроводную технологию Bluetooth, устройство должно иметь возможность интерпретировать определенные профили Bluetooth, которые являются определениями возможных приложений и определять общее поведение, которое устройства с поддержкой Bluetooth используют для связи с другими устройствами. -Как вариант, вы можете использовать пакет [chocolatey](https://chocolatey.org/courses/getting-started/what-is-chocolatey) созданный [@superbonaci](https://github.com/superbonaci): +Galaxy Buds определяют два профиля Bluetooth: A2DP (Advanced Audio Distribution Profile) для потоковой передачи / управления аудио и SPP (Serial Port Profile) для передачи двоичного потока. Производители часто используют этот профиль (который основан на протоколе RFCOMM) для обмена данными конфигурации, выполнения обновлений прошивки или отправки других команд на устройство Bluetooth. -``` -choco install galaxybudsclient -``` +Несмотря на то, что профиль A2DP стандартизирован и задокументирован, формат фактических двоичных данных, которыми обменивается этот протокол RFCOMM, обычно не документируется и является собственностью компании производителя. -## Переводчики +Чтобы реконструировать этот формат данных, я начал с анализа структуры двоичного потока, отправляемого наушниками. Позже я также разобрал официальные приложения Galaxy Buds для Android, чтобы лучше понять внутреннюю работу этих устройств. Работая над этим, я записывал свои мысли в небольшой блокнот. Хотя они не такие и красивые, я приложил их ниже. Имейте в виду, что я не стал записывать каждую деталь. Проверьте исходный код, чтобы получить более подробную информацию о структуре протокола. -* [@Florize](https://github.com/Florize) - Корейский и Японский переводы -* [@ArthurWolfhound](https://github.com/ArthurWolfhound) - Русский и Украинский переводы -* [@erenbektas](https://github.com/erenbektas) - Турецкий перевод -* [@kakkk](https://github.com/kakkk) - Китайский перевод -* [@efrenbg1](https://github.com/efrenbg1) вместе с Andrew Gonza - Испанский перевод ++ Galaxy Buds (2019) Notes • + Galaxy Buds Plus Notes +
+ + +Присмотревшись к Galaxy Buds Plus, я также заметил некоторые необычные функции, такие как режим отладки прошивки, неиспользуемый режим сопряжения и дампер адресов Bluetooth. Я задокументировал эти результаты здесь: + ++ Galaxy Buds Plus: Unusual features +
+ +В настоящее время я занимаюсь модификацией и реверс-инжинирингом прошивки для Buds +. На момент написания у меня есть два инструмента для извлечения и анализа с помощью официальных двоичных файлов прошивки. Посмотрите их здесь: + ++ Firmware Downloader • + Firmware Extractor +
+ +## Внести вклад + +Предложения функций, отчеты об ошибках и запросы на перенос (пулл реквесты) любого рода всегда приветствуются. + +Если вы хотите сообщить об ошибках или предложить свои идеи для этого проекта, вы можете [подать запрос](https://github.com/ThePBone/GalaxyBudsClient/issues/new/choose) с подходящим шаблоном. [Посетите нашу вики](https://github.com/ThePBone/GalaxyBudsClient/wiki/2.-How-to-submit-issues) для получения подробного объяснения. + +Если вы планируете помочь нам в переводе этого приложения, [просмотрите инструкции в нашей вики](https://github.com/ThePBone/GalaxyBudsClient/wiki/3.-How-to-help-with-translations). Знания в области программирования не требуются, вы можете протестировать свои переводы без установки каких-либо инструментов разработки перед отправкой запроса на перенос. + +Если вы хотите внести свой собственный код, вы можете просто отправить простой запрос на перенос с объяснением ваших изменений. Для более крупных и сложных вкладов было бы неплохо, если бы вы могли открыть запрос (или написать мне в Telegram [@thepbone](https://t.me/thepbone)), прежде чем начинать работу над ним. + +## Дорожная карта + +Выход версии 4.0 запланирован на конец 2020 и принесет кросс-платформенную поддержку. Вот что удалось реализовать уже сейчас: + + +- [x] Move to .NET Core 3.1 +- [x] Linux: Implement native Bluetooth interface +- [ ] Windows: Implement native Bluetooth interface +- [ ] Windows/Linux: Native tray icon support (libappindicator) +- [ ] Cross-platform Bluetooth device selection dialog +- [ ] Port user interface to AvaloniaUI.NET +- [ ] Linux: Solve NVIDIA incompatibility with libSkia -## Соучастники +Вклады в отношении этой дорожной карты очень ценятся. Новая реализайия доступна на ветке [`avalonia-rewrite`](https://github.com/ThePBone/GalaxyBudsClient/tree/avalonia-rewrite). + +## Имена + +#### Соучастники + +* [@ArthurWolfhound](https://github.com/ArthurWolfhound) - Шаблоны уведомлений о проблемах, вики и переводы * [@AndriesK](https://github.com/AndriesK) - Исправление ошибок при работе с Buds Live -* [@githubcatw](https://github.com/githubcatw) - Програмная основа для диалога подключения -* [@superbonaci](https://github.com/superbonaci) - Пакет Chocolatey +* [@githubcatw](https://github.com/githubcatw) - Програмная основа диалога подключения + +#### Переводчики + +* [@ArthurWolfhound](https://github.com/ArthurWolfhound) - Русский и Украинский переводы +* [@PlasticBrain](https://github.com/fhalfkg) - Корейский и Японский переводы +* [@erenbektas](https://github.com/erenbektas) - Турецкий перевод +* [@kakkk](https://github.com/kakkk) , [@KevinZonda](https://github.com/KevinZonda) и [@ssenkrad](https://github.com/ssenkrad) - Китайский перевод +* [@efrenbg1](https://github.com/efrenbg1) и Andrew Gonza - Испанский перевод +* [@giovankabisano](https://github.com/giovankabisano) - Индонезийский перевод +* [@lucasskluser](https://github.com/lucasskluser) - Португальский перевод +* [@alb-p](https://github.com/alb-p) - Итальянский перевод +* [@Buashei](https://github.com/Buashei) - Польский перевод + +## Лицензия -___ +Этот проект распространяется по лицензии [GPLv3](LICENSE). Он никоим образом не связан с Samsung и не контролируется ею. -Посетите мой сайт:
+ English | 中文 | Русский | 日本語 | Українська | 한국어
+ Увага: файли "Про проект" підтримуються перекладачами і можуть час від часу не відповідати поточній версії. Для новішої інформації покладайтеся на англоязичний варіант.
+
+ Основні можливості • + Завантажити • + Як це працює • + Зробити внесок • + Дорожня карта • + Імена • + Ліцензія +
+ -(Ви можете знайти завантаження у розділі [релізів](https://github.com/thepbone/galaxybudsclient/releases)) -Цей клієнт є результатом мого дослідження спеціальної версії послідовного протоколу RFComm, який Buds використовують для отримання та відправки бінарних (конфігураційних) даних. Якщо вас цікавить структура протоколу і його послідовні повідомлення, я рекомендую вам вивчити мої замітки, які я зробив під час реверс-інжинірингу: +## Основні можливості -* [Нотатки про Buds (2019), англійська](GalaxyBudsRFCommProtocol.md) -* [Нотатки про Buds Plus, англійська](Galaxy%20Buds%20Plus%20RFComm%20Protocol%20Notes.md) +Налаштуйте та керуйте будь-яким пристроєм Samsung Galaxy Buds і інтегруйте їх в свій комп'ютер. -## Функції +Крім стандартних функцій, відомих з офіційного додатку для Android, цей проект допоможе вам розкрити весь потенціал ваших навушників і реалізує нові функції, такі як: -**Нові функції** (в доповнення уже існуючим): +* Детальна статистика батареї +* Діагностика і заводське самотестування +* Безліч прихованої налагоджувальної інформації +* Настроювані дії утримання сенсорної панелі +* і багато іншого... -* Сенсорна панель: Налаштованиі дії (натиснути і затримати) для запуску програм, керування еквалайзером, керування гучністю звукового фону, ...[1] -* Відновити програвання коли навушники одягнуті -* Контекстне меню в системному треї з даними про заряд батареї -* Відображення розширенних даних сенсорів на головному екрані, що включає: - * Вольти і напруга на вбудованому АЦП (Аналого-цифровий перетворювач) обох навушників - * Температура обох навушників - * Більш точний статус заряду (замість кроків у 5 відсотків) -* Виконання самодіагностики усіх компонентів на борту -* Відображення різноманітної інформації (для налагодження), включаючи: - * Апаратна версія - * (Сенсорна панель) Версія прошивки - * Адреса Bluetooth обох навушників - * Серійні номери обох навушників - * Інформація про збирання (Дата компіляції, Ім'я збиральника) - * Тип батареї - * Дані інших сенсорів -* Еквалайзер: розблокуйте функцію 'Оптимізувати для Dolby' -* Сенсорна панель: Комбінуйте керування гучністю разом з іншими діями[1] +## Завантажити -> [1] Майте на увазі що додаток Wearable автоматично скине налаштування цих функцій при відкритті налаштувань Сенсорної панелі на телефоні -> -> [2] Тільки для Buds (2019) +Завантажте файли для Windows у розділі [релізи](https://github.com/ThePBone/GalaxyBudsClient/releases). Будь ласка, прочитайте нотатки до релізу перед встановленням. -## Встановлення + -Ви можете [**завантажити**](https://github.com/ThePBone/GalaxyBudsClient/releases) повністю автоматичний пакет інсталятора в [**розділі релізів**](https://github.com/ThePBone/GalaxyBudsClient/releases) цього репозиторія! +## Як це працює -*Ця программа вимагає [.Net Framework](https://dotnet.microsoft.com/download/dotnet-framework/net461) 4.6.1 або новіше* +Щоб використовувати бездротову технологію Bluetooth, пристрій повинен мати можливість інтерпретувати певні профілі Bluetooth, які є визначеннями можливих додатків і визначати загальну поведінку, яку пристрої з підтримкою Bluetooth використовують для зв'язку з іншими пристроями. -![Downloads](https://img.shields.io/github/downloads/ThePBone/GalaxyBudsClient/total) +Galaxy Buds визначають два профілі Bluetooth: A2DP (Advanced Audio Distribution Profile) для потокової передачі / управління аудіо і SPP (Serial Port Profile) для передачі двійкового потоку. Виробники часто використовують цей профіль (який заснований на протоколі RFCOMM) для обміну даними конфігурації, виконання оновлень прошивки або відправки інших команд на пристрій Bluetooth. -Як варіант, ви можете використати пакет [chocolatey](https://chocolatey.org/courses/getting-started/what-is-chocolatey) створений [@superbonaci](https://github.com/superbonaci): +Незважаючи на те, що профіль A2DP стандартизований і задокументований, формат фактичних двійкових даних, якими обмінюється цей протокол RFCOMM, зазвичай не документується і є власністю компанії виробника. -``` -choco install galaxybudsclient -``` +Для того, щоб перепроектувати цей формат даних, я розпочав з аналізу структури двійкового потоку, що надсилається навушниками. Пізніше я також розібрав офіційні програми Galaxy Buds для Android, щоб отримати глибше розуміння внутрішньої роботи цих пристроїв. Працюючи над цим, я записав свої думки в невеликий блокнот. Незважаючи на те, що вони не такі вже і красиві, я приклав їх нижче. Майте на увазі, що я не записував кожну окрему деталь. Перевірте початковий код, щоб отримати більш детальну інформацію про структуру протоколу. -## Перекладачі ++ Galaxy Buds (2019) Notes • + Galaxy Buds Plus Notes +
-* [@Florize](https://github.com/Florize) - Корейський та Японський переклади -* [@ArthurWolfhound](https://github.com/ArthurWolfhound) - Російський та Український переклади -* [@erenbektas](https://github.com/erenbektas) - Турецький переклад -* [@kakkk](https://github.com/kakkk) - Китайський переклад -* [@efrenbg1](https://github.com/efrenbg1) разом з Andrew Gonza - Іспанський переклад -## Співучасники +Придивившись до Galaxy Buds Plus, я також помітив деякі незвичайні функції, такі як режим налагодження прошивки, невикористаний режим сполучення і дампер адрес Bluetooth. Я задокументував ці результати тут: + ++ Galaxy Buds Plus: Unusual features +
+ +В даний час я займаюся модифікацією і реверс-інжинірингом прошивки для Buds +. На момент написання у мене є два інструменти для витягання і аналізу за допомогою офіційних двійкових файлів прошивки. Подивіться їх тут: + ++ Firmware Downloader • + Firmware Extractor +
+ +## Зробити внесок + +Пропозиції функцій, звіти про помилки та запити на перенесення (пулл реквести) будь-якого роду завжди вітаються. + +Якщо ви хочете повідомити про помилки або запропонувати свої ідеї для цього проекту, ви можете [подати запит](https://github.com/ThePBone/GalaxyBudsClient/issues/new/choose) з відповідним шаблоном. [Відвідайте нашу вікі](https://github.com/ThePBone/GalaxyBudsClient/wiki/2.-How-to-submit-issues) для отримання докладного пояснення. + +Якщо ви плануєте допомогти нам у перекладі цього додатка, [перегляньте інструкції в нашій вікі](https://github.com/ThePBone/GalaxyBudsClient/wiki/3.-How-to-help-with-translations). Знання в області програмування не потрібні, ви можете протестувати свої переклади без встановлення будь-яких інструментів розробки перед відправкою запиту на перенесення. + +Якщо ви хочете внести свій власний код, ви можете просто відправити простий запит на перенесення з поясненням ваших змін. Для більших і складних вкладів було б непогано, якби ви могли відкрити запит (або написати мені в Telegram [@thepbone](https://t.me/thepbone)), перш ніж починати роботу над ним. + +## Дорожня карта + +Випуск версії 4.0 запланований на кінець 2020 і принесе кросс-платформену підтримку. Ось що вже вдалося реалізувати: + + +- [x] Move to .NET Core 3.1 +- [x] Linux: Implement native Bluetooth interface +- [ ] Windows: Implement native Bluetooth interface +- [ ] Windows/Linux: Native tray icon support (libappindicator) +- [ ] Cross-platform Bluetooth device selection dialog +- [ ] Port user interface to AvaloniaUI.NET +- [ ] Linux: Solve NVIDIA incompatibility with libSkia + +Внески по відношенню до цією дорожньої карти дуже цінуються. Нова реалізація доступна на гілці [`avalonia-rewrite`](https://github.com/ThePBone/GalaxyBudsClient/tree/avalonia-rewrite). + +## Імена + +#### Співучасники + +* [@ArthurWolfhound](https://github.com/ArthurWolfhound) - Шаблони повідомлень про проблеми, вікі та переклади * [@AndriesK](https://github.com/AndriesK) - Виправлення помилок при роботі з Buds Live -* [@githubcatw](https://github.com/githubcatw) - Програмна основа для діалогу підключення -* [@superbonaci](https://github.com/superbonaci) - Пакет Chocolatey +* [@githubcatw](https://github.com/githubcatw) - Програмна база діалогу підключення + +#### Перекладачі + +* [@ArthurWolfhound](https://github.com/ArthurWolfhound) - Російський та Український переклади +* [@PlasticBrain](https://github.com/fhalfkg) - Корейський та Японський переклади +* [@erenbektas](https://github.com/erenbektas) - Турецький переклад +* [@kakkk](https://github.com/kakkk) , [@KevinZonda](https://github.com/KevinZonda) і [@ssenkrad](https://github.com/ssenkrad) - Китайський переклад +* [@efrenbg1](https://github.com/efrenbg1) і Andrew Gonza - Іспанський переклад +* [@giovankabisano](https://github.com/giovankabisano) - Індонезійський переклад +* [@lucasskluser](https://github.com/lucasskluser) - Португальский переклад +* [@alb-p](https://github.com/alb-p) - Італійський переклад +* [@Buashei](https://github.com/Buashei) - Польський переклад + +## Ліцензія -___ +Цей проект розповсюджується за ліцензією [GPLv3](LICENSE). Він ніяким чином не пов'язаний з Samsung і не контролюється нею. -Відвідайте мій сайт: