Сообщество - ИТ-проекты пикабушников

ИТ-проекты пикабушников

590 постов 3 429 подписчиков

Популярные теги в сообществе:

8

С помощью нейросетей сделал сервис для поиска битых ссылок, не умея программировать

Я решил провести эксперимент — сколько времени потребуется, чтобы с нуля сделать полноценный сервис с первыми пользователями. Вот нет ничего, даже идеи. Надо эту идею найти, накодить само приложение, и как-то донести его до первых настоящих людей.

Программировать я не умею, людей под это дело нанимать не хочу, изучать языки программирования лень. Выход — все по-максимуму делать в нейросетях. Ну не только же картинки смешные в них генерить, надо и для дела использовать.

Самый простой для запуска на коленке сервис — это расширение для Хрома, поэтому решил делать его.

Спойлер — занимался этой фигней по вечерам, ушло чуть больше месяца или 25-30 часов чистого времени. В теории, можно было все сделать за 4 рабочих дня.

Спойлер 2 — прошло 2 месяца после запуска, у расширения уже 542 установки и 250 пользователей в неделю. То есть половина установивших им даже пользуется!

Больше всего пользователей из России, но есть ощутимое количество из Бразилии, Японии, США и Индии. На расширение уже пошел небольшой органический трафик, его находят люди из самых разных стран. Прикольно!

Теперь о том, как все это делал.

Провел исследование и выбрал идею

Попросил ChatGPT в режиме Deep Research найти 50 идей для расширения по таким критерям:

— Такое расширение уже существует, и у него больше 10к пользователей

— Расширение направлено на решение рабочих задач, а не на развлечение

— Идея довольно простая, и ее может осилить начинающий разработчик

Я все это дело изучил, потыкал расширения, выбрал идеи, которые мне зашли, у которых есть понятная монетизация. Из них выбрал те, функции которых регулярно гуглят.

Посоветовался с ChatGPT насчет сложности разработки и слабостей конкурентов — и выбрал идею с проверкой битых ссылок.

Суть очень простая — этот плагин собирает все ссылки на текущей странице, проверяет их и показывает, какие работают, а какие выдают ошибки. Например, 404. Одну невидимую битую ссылку на главной своего сайта я уже нашел =)

Результаты можно выгрузить в CSV, а можно посмотреть сразу на месте. Все найденные ссылки подсвечиваются на сайте, битые выделяются красным.

Сделал «упаковку»

Собрал в сервисе Semrush ключи и вместе с ChatGPT сгенерил описание страницы в магазине расширений Хрома. Генерировал на английском, затем перевел это все на 52 языка. Под самые ходовые языки тоже подбирал ключи и заморачивался с сеошкой, остальные перевел как перевелось и все.

В Figma сделал баннер для Стора, а в ChatGPT сгенерировал логотип.

Накодил нейронками в Cursor

Интерфейс расширений нарисовал сам в Figma. А дальше все делали нейросети.

Выгрузил его в HTML, закинул в Cursor и дальше по шагам просил добавлять функционал ко всем элементам.

В духе «Вот у нас есть кнопка экспорта, давай при клике по ней будет скачиваться CSV вот такого вида». А вот мы запускаем расширение — пусть оно сразу же начнет сканировать страницу и добавлять ссылки в список. А теперь пусть все найденные ссылки подсветит. А теперь пусть проверит их и выведет статусы. Ну и так далее. Много-много маленьких шагов

8 часов вайбкодинга — и все готово. Работал в Cursor через Claude Opus 4, потратил что-то в районе $90 на API

Я не знаю Python, сам ни строчки кода руками не написал. Просто говорил словами, чего надо сделать, тестировал, кидал скриншоты ошибок в нейронку и просил починить.

Прошел модерацию Гугла и выложил расширение

В анкете была куча сложных вопросов на английском, их я тоже кидал в ChatGPT и просил сгенерировать ответ. Так все и сделал.

Расширение успешно прошло модерацию и появилось в магазине Хрома → https://chromewebstore.google.com/detail/broken-link-checker...

Что хочу делать дальше

С помощью нейросетей ищу статьи в духе «5 лучших инструментов для SEO-специалистов», и отправляю их авторам письма. Мол, смотрите, какое хорошее расширение, добавьте в свою статью, пожалуйста, я вам уже даже готовый текст написал на всякий случай.

Добил расширения во всякие каталоги сервисов, какие нашел.

А вообще, просто смотрю, как у расширения появляются пользователи и хорошие отзывы. Когда наберется несколько тысяч человек, начну добавлять платные функции — например, проверку всего сайта целиком, а не только одной страницы.

Эксперимент считаю удачным — я действительно накодил и запустил полностью рабочее расширение, на английском языке, не особо-то хорошо зная английский и не умея программировать. Им пользуются живые люди, и вроде даже довольны.

Показать полностью 2

VOID набрал 135 звезд на GitHub!

VOID — это кроссплатформенное приложение для управления заметками, основанное на концепции second-brain (второй мозг). Представьте комбо из гибкости Obsidian и структурированной организации Notion, но с акцентом на локальное хранение и приватность.

Что дальше?🤔
Позвольте поделиться стратегическими планами на проект и сервер:
• Связывание заметок, глобальная индексация задач и тегов.
• Базы данных (аналогично Notion), включая Gallery и Kanban для визуализации проектов.
• Улучшения синхронизации сервера, с self-hosted Docker-контейнером для удобной настройки.
• Полный редизайн всего приложения (да, у нас наконец есть дизайнер!).

И до кучи — первая бета выйдет очень скоро!

Присоединяйся к VOID!

  • 📂 Смотри код и вноси идеи: GitHub

  • 💬 Обсуждай с нами: Telegram

  • 💸 Поддержи проект: Boosty

  • 📱 Кроссплатформенность: Скоро на Windows, macOS, Linux, Android и iOS!

Хочешь стать бета-тестером или предложить фичу? Пиши в Telegram или оставляй коммент здесь. VOID — это твой инструмент для идей, и мы строим его вместе с вами! 💡

Показать полностью 2

Проклятие создателя. Как мы придумали идеального бота, которым никто не мог воспользоваться

В прошлых постах мы громко и с важностью рассказывали о проекте «Поэтропия» и Telegram-боте «Привет, Поэт». Прочитать их можно в нашем профиле тут.

Но, как показала ваша обратная связь, за что вам большое спасибо (!), ботом оказалось неудобно пользоваться.

Наша команда была увлечена грандиозными идеями и сложными смыслами, что совершенно забыла о простоте и удобстве для обычных людей, для вас.

Мы создавали «космический корабль», хотя начать следовало с велосипеда.


Проблемы и вопросы, которые мы исправляли и обсуждали в течение этой недели:

  • Начальная регистрация

    «Наворотили много всего хорошего, но людям, оказывается, неудобно».

    Ранее, как только вы переходили в бота, вам предлагалось пройти регистрацию. Она состояла из псевдонима и пола. Именно последняя опция отпугнула некоторых. Ведь, непонятно, где связь между полом и поэзией?

В прошлой версии бота первое сообщение выглядело так, из-за чего им было неудобно пользоваться.

В прошлой версии бота первое сообщение выглядело так, из-за чего им было неудобно пользоваться.

  • Выбор пола

    Мы хотели сделать наш бот инклюзивным и учесть интересы всех, вплоть до разных религиозных конфессий, что ввели сложный выбор пола. К тому же, некоторым комфортнее получать и отправлять стихотворения только собственному полу. В итоге эта забота о меньшинстве отпугнула большинство, которое просто не поняло, зачем это нужно.

Так мы оказались между Сциллой и Харибдой...

А как думаете Вы: оставить выбор пола?
Всего голосов:
  • А нужна ли вообще регистрация?

    У команды были дебаты после обсуждения первых двух пунктов. Мы хотели дать пользователям возможность ознакомиться со всей “кухней” бота до регистрации. Тогда возникла техническая проблема – данные нужно где-то хранить. Если пользователь не зарегистрирован, то не понятно, от кого приходит записанное стихотворение.

Уже сейчас первое сообщение выглядит так. Согласитесь, намного понятнее и комфортнее стало пользоваться? Сразу понимаешь, куда тыкать)

Уже сейчас первое сообщение выглядит так. Согласитесь, намного понятнее и комфортнее стало пользоваться? Сразу понимаешь, куда тыкать)


Таким образом благие намерения команды обернулись неудобством пользователю и технической трудностью для нашего разработчика Александра.

Сейчас команда активно решает эти проблемы и мы просим у вас времени для реализации всех планов!

А если вы уже сейчас хотите опробовать бета-версию бота, то переходите в Telegram и записывайте первое стихотворение!

Показать полностью 2 1
16

Жарко летом? Охладись

Привет. Я продолжаю разрабатывать сервер для Lineage 2 C1 на JavaScript Проект

Продолжая работать над скилами, заметил, что некоторые атакующие скилы можно направить на себя.

Блог про разработку сервера для Lineage 2 в телеге https://t.me/lineage2js

Показать полностью 1

VOID: Ваш локальный second-brain

VOID — это кроссплатформенное приложение для управления заметками, основанное на концепции second-brain (второй мозг). Оно помогает пользователям хранить, упорядочивать и использовать важную информацию: заметки, планы, идеи, знания и цели. Проект находиться на стадии разработки и в будущем будет сочетать минимализм Obsidian (локальное хранение, Markdown) и гибкость Notion (списки, таблицы), предлагая уникальный подход с акцентом на локальность, модульность и философию open-source.

Присоединяйся к VOID!

  • 📂 Смотри код и вноси идеи: GitHub

  • 💬 Обсуждай с нами: Telegram

  • 💸 Поддержи проект: Boosty

  • 📱 Кроссплатформенность: Скоро на Windows, macOS, Linux, Android и iOS!

Хочешь стать бета-тестером или предложить фичу? Пиши в Telegram или оставляй коммент здесь. VOID — это твой инструмент для идей, и мы строим его вместе с вами! 💡

Мы не используем ваши пожертвования для поддержки России или Украины.
Все средства с вашей материальной поддержки (донатов) идут исключительно на нужды команды разработчиков.

Показать полностью 1
1

Как мы сделали Telegram-бота для обмена стихотворениями путем голосового чтения

Всем привет! На связи Анна, и сегодня вы узнаете историю создания проекта «Поэтропия» и какие же функции можно будет увидеть в «Привет, поэт!».

В прошлом посте я рассказала о своем знакомстве с проектом, и что для меня в нем ценно. Прочитать его можно тут.

Для меня «Поэтропия» – это не чувствовать одиночество, не спешить, не читать по диагонали. Это про живого человека рядом, про умение замедлиться и услышать, что звучит в наушниках. Это про всех нас, про людей. Подробнее о проекте смотрите здесь.

Небольшие спойлеры!

Небольшие спойлеры!

Так что же такое эта загадочная Поэтропия?

Проект «Поэтропия» – это попытка найти баланс между бесконечным скроллингом и человечностью.

В рамках данного проекта под руководством Андрея Гунявина и Александра был создан Telegram-бот «Привет, поэт!», где вы можете:

  • Слушать живые чтения стихов (стихотворение писателей или собственного сочинения). Это помогает почувствовать рядом с собой не винтик в системе ИИ, а человека;

  • Оценивать не стройности слога и точности рифмы, а выразительность, эмоцию в голосе;

  • Делиться своими записями – даже если вы не поэт. Хотя мы считаем, что поэзия живет в каждом из нас!

Путь от идеи до работающего бота оказался сложнее, чем мы думали. Рассказываем как это сделано, и для чего.

Зачем наш Telegram-бот, если есть книги?

Мы верим, что поэзия – форма общения наших душ. Это не только текст, но и голос, вибрация. Стихотворения написаны, чтобы их произносили вслух, но в цифровую эпоху это почти исчезло. Разве что на уроках литературы в школе можно услышать родное «Мороз и солнце; день чудесный!».

Наш проект соединяет современность и жизнь, а наш бот – попытка вернуть звучащее слово через технологии.

Наш проект соединяет современность и жизнь, а наш бот – попытка вернуть звучащее слово через технологии.

Как работает «Привет, поэт»?

Механика бота проста и доступна всем:

  • Вы получаете случайное голосовое сообщение со стихом (из базы Yandex Cloud);

  • Оцениваете его с помощью понятной системы оценок и хэштегов (важна не правильность, а эмоция и дух);

  • После этого можете записать свое чтение (можно стихотворения авторов-классиков, так и собственного сочинения).

А вот и прекрасный помощник, в котором хранится ВСЁ: стихотворения, видео-отзывы, рейтинг.

А вот и прекрасный помощник, в котором хранится ВСЁ: стихотворения, видео-отзывы, рейтинг.

Техническая сторона:

  • Хранение аудио: Сначала думали о Google Drive, но выбрали Yandex Cloud (1 ТБ, быстрая загрузка, дешевле). Сейчас благодаря Yandex мы можем обработать около 10000 запросов;

  • Хранение и отправка видео-отзывов: Telegram → конвертация на нашем сервере (TimeWeb) → Yandex Cloud;

  • Хэштеги и метаданные: Хранятся отдельно, чтобы потом анализировать предпочтения пользователей. Атрибуты хэштегов позволяют отследить, когда был поставлен хэштег, кейс-контент и описание.

Сервис TimeWeb, для которого написали кастомный код. Он будет ниже)

Сервис TimeWeb, для которого написали кастомный код. Он будет ниже)

Проблемы, с которыми столкнулись.

  • Конвертация видео: Telegram отправляет их в своем формате, не принимаемом в Yandex Cloud. Написали кастомный код на собственном сервере в TimeWeb;

  • Способы оплаты: Не все международные сервисы по оплате доступны на территории РФ. Было принято решение создать 2 варианта подписок: для резидентов РФ, и других стран (сервис Stripe). Это позволит нам принимать способы оплаты из всех уголков планеты и объединить тысячи людей.

А вот и обещанный код.

В данном случае мы создали функцию сохранения видео.

В данном случае мы создали функцию сохранения видео.

Объявляем асинхронную функцию в которую передаем идентификатор пользователя и сообщения, словарь, который содержит путь к видео и экземпляр бота, через который идет скачивание видео: ‘async def save_video(user_id: int, message_id: int, data: dict, bot: Bot):’

Получаем путь к видео: file_path = data.get("file_path")

Скачиваем файл с сервера telegram: video_file = await bot.download_file(file_path)

Создаем временный файл: async with aiofiles.tempfile.NamedTemporaryFile('wb', delete=False, suffix='.mp4') as tmp_file:

Цикл читает видео по 1мб, важно заметить, что <!--noindex--><a href="https://pikabu.ru/story/kak_myi_sdelali_telegrambota_dlya_obmena_stikhotvoreniyami_putem_golosovogo_chteniya_13055292?u=http%3A%2F%2Ftmp_file._file.name&t=tmp_file._file.name&h=5c387664cbc2f91dfb4e3764fec4fd31a2b4aeaf" title="http://tmp_file._file.name" target="_blank" rel="nofollow noopener">tmp_file._file.name</a><!--/noindex--> - небезопасный доступ к приватному полю, но в дальнейшем это будет исправлено &#x1F642;

Цикл читает видео по 1мб, важно заметить, что tmp_file._file.name - небезопасный доступ к приватному полю, но в дальнейшем это будет исправлено 🙂

Формируем ключ для загрузки в s3 (объектно облачное хранилище): s3_key = f"feedbacks/video_{user_id}_{message_id}.mp4"

Создаем асинхронный клиент s3 и загружаем видео на yandex cloud os.remove(tmp_path) - удаляем временный файл.

Создаем асинхронный клиент s3 и загружаем видео на yandex cloud os.remove(tmp_path) - удаляем временный файл.

Создаем путь к файлу в стиле s3, но не http-ссылка, а логический: s3_url = f"s3://{YANDEX_VIDEOBACKET_NAME}/{s3_key}"

Сохраняем наш путь в бд: await rq.set_feedback_video(tg_id=user_id, way_to_video=s3_url)

Планы на будущее.

  • «Рюкзачок стихотворений»: анализ оценок, полученных вами от других пользователей позволит узнать о себе больше. Мы отражаемся в других людях словно зеркала, и эта функция будет аккумулировать базу данных каждого пользователя;

  • Возврат к лекциям: Пока бот – первый шаг в мир технологий, но мы не забыли с чего начинался наш путь. Рассказ о нем будет позже, ведь всему свое время.

Поэзия – форма общения душ. «Привет, поэт!» – способ дать душе говорить.

Поддержите наш проект и попробуйте сами в Telegram: @Poetropy_bot. Первые два прослушивания бесплатны!

Показать полностью 7
16

DSL KeyPad — ввод более 4700 символов Юникода прямо с клавиатуры

Программа даёт доступ к внушительному перечню символов Юникода прямо с клавиатуры. Основной фокус — увеличение охвата латиницы и кириллицы без надобности в отдельных языковых раскладках, помимо английской и русской. Но этим инструмент не ограничивается.

Написана на AutoHotkey v2

Прескриптум: из-за отсутствия элемента блока кода все примеры кода будут ссылкой на GitHub Gist’ы.


Зачем? — У меня и самой был запрос на такую программу. Программу с кучей «нестандартных» символов. Существующие решения не отвечали моим потребностям и тогда я решила создать своё, подходящее под мои хотелки: многоязычный ввод, ввод типографских, математических и даже алхимических символов. И теперь я надеюсь, что сие «изобретение» окажется полезным не только для меня.

Такой инструмент необходим мне для разработки вселенной — построение канона культур, писательство и работа с языками. Создавать новые языки на основе существующих систем ныне будет проще — все нужные символы как на ладони.

Примеры названий языков и систем, написанные с помощью моей программы:

  • Қазақ тілі, Хуэйзў йүян, Забони тоҷикӣ, Йағнобӣ зивок, Аԥсуа бызшәа, Авар мацӏ, Українська мова, Словѣньскъ ѩꙁꙑкъ, Црногорски језик, Лимба Рꙋмѫнѣскъ, Итәнмәӈин крвэԓхатас, Даһур Усүүэ, Азәрбајҹанҹа, Башҡорт теле, Тэлэңгэт, Чӑваш чӗлхи…

  • Ænglisċ sprǣċe, Français, Tiếng Việt, Hànyǔ Pīnyīn, Norrœnt mál, Limba Română, Español, Język polski, Čeština, Bokmål, Tamaziɣt, Türkçe, Sää’mǩiõll…


Установка и репозиторий

Репозиторий проекта на GitHub: DSL-KeyPad

Установка:

Во-первых, необходимо установить сам AuotHotkey 2.*, скачав с соответствующего сайта или через терминал:

winget install AutoHotkey.AutoHotkey

Затем:

  1. Выбрать самую последнюю версию DSL KeyPad из релизов репозитория или скачать с SourceForge.

  2. Распаковать содержимое архива куда угодно — это и будет директорией установки.

  3. Запустить DSLKeyPad.exe или DSLKeyPad.ahk файл.

  4. При необходимости в настройках можно установить автозагрузку при старте системы.

    1. *При перемещении папки необходимо будет снова установить автозагрузку, т.к. путь не обновляется автоматически.

  5. Нужен шрифт Noto Serif, но при его отсутствии программа сама предложит установку.


GUI с представлением списка доступных символов с их хоткеями или «рецептами» (см. далее)

GUI с представлением списка доступных символов с их хоткеями или «рецептами» (см. далее)

Краткий экскурс

Идея «DSL KeyPad» родилась, как было упомянуто выше, из собственной потребности в «нестандартных» символах. Сначала я пользовалась «Типографской раскладкой» Ильи Бирмана (и пользуюсь по сей день в паре со своим инструментом), но этого мне оказалось мало — она не давала мне всего необходимого.

Работа над книгой стала отправным толчком: мне хотелось использовать в ней буквы «Ў», «Ӯ», «Ӣ», «Ō» и пр.: Сўкэнори, «Записи времён Тōбō» (Tōbō nendai-ki), Фӯдзин. Я искала и пробовала другие решения — например, WinCompose, — но по итогу это привело меня к мысли «всё не совсем то». Тогда я уже занималась написанием своего скрипта, ещё совсем простого, и продолжила его развивать.

Первая версия была до банальности примитивной, ~20 биндов формата обычных привязок:

<^<!m:: Send("{U+0304}") ; Combining macron

<^<!b:: Send("{U+0306}") ; Combining breve

<^>!>+1:: Send("{U+2003}") ; Em Space

<^>!>+2:: Send("{U+2002}") ; En Space

<^<!e:: Send("{U+045E}") ; (Ў)

Со временем мою голову начали посещать всё новые идеи и желание хотя бы попробовать их реализовать. Желание сделать что-то сложнее, разнообразнее, и что могло бы охватить все мои потенциальные символьные хотелки. Как итог — процесс, конечно, сильно затянулся, да получился какой-то монструозный ООП’оид, но результатом я довольна (есть что улучшать, и я буду это улучшать по мере возможности).

Думаю тут же следует упомянуть, что я не программист. Максимум кодер. В начале разработки так вообще была утёнком тем ещё и бегала частенько к нейронке (с которой контакт заладился плохо — не умел гпт с автохоткеем нормально помочь… и хорошо — лишний пинок самой думать над кодом).

Краткий перечень возможностей

  • Как описано в заголовке — поддержка более 4 700 символов Юникода, включая: пунктуацию, математические символы, символы валют, специальные символы, алхимические и т.д.

  • «Многослойный» набор привязок, в основном — раздельных для английского и русского языков ([англ.] RAlt + A → Ă, RAlt + Z → Ż [рус.] RAlt + Ф → Ѳ, RAlt + Я → Ѧ). Включает поддержку пользовательских привязок в JSON‐формате.

  • Режим композиции — активируется двойным нажатием RAlt и позволяет получать одни символы из последовательности других («рецепта») (AE → Æ OE → Œ A◌̆◌́ → Ắ ІѪ → Ѭ ДЧ → Ԭ ΣΤ → Ϛ, αͺ → ᾳ). Включает поддержку пользовательских рецептов в INI/JSON/XCompose форматах.

  • Альтернативные режимы ввода для форм письменности, отличных от латиницы и кириллицы (греческая письменность, руническая, глаголица, финикийская, этрусская, тюркская, пермская и пр. виды письменности; включает и Международный фонетический алфавит).

  • Вариации глифов — режимы, позволяющие вводить альтернативные варианты символов (A → ᴬ 𝐴 𝐀 𝑨 𝖠 𝘈 𝗔 𝘼 𝙰 ᴀ 𝔄 𝕬 𝒜 𝓐 𝔸). Интерфейс схож с предыдущим пнуктом, но сама фича работает чуть-чуть иначе.

  • Переключение режима ввода между символами Юникода [Ă Ǣ], HTML-энтити/мнемоники [&Abreve; &#482;] и LaTeX [\u{A} \={\AE}] (если LaTeX команды нет — введёт символ Юникода) (RAlt + RShift + F1).

  • Поиск символов по «тегам». У большинства из символов локальной библиотеки есть два и более тегов, по сути, представляющих из себя варианты названий, которые можно вводить как полностью, так и частично, чтобы получить результат (прописная буква Еры глаголицы или гла еры → ⰟⰊ).

  • Внутренние раскладки клавиатуры, позволяющие использовать отличное от QWERTY/ЙЦУКЕН расположение привязок. Включает поддержку пользовательских раскладок в JSON‐формате.

  • Вспомогательные TELEX/VNI-подобные режимы ввода для вьетнамского языка (с щепоткой джарайского) и для пиньиня.

  • Мини-режимы для ввода надстрочных/подстрочных символов цифрового ряда (LWin LAlt + ↑/↓), при этом CapsLock зеркалит вводимые символы (при активном надстрочном режиме — активация CapsLock заставит вводиться подстрочные, и наоборот).

  • Мини-режим для ввода римских цифр (отдельных символов Юникода) (LWin LAlt RShift + ↑): ⅠⅡⅢⅣⅤⅥⅦⅧⅨⅩⅪⅫ…

  • Возможность добавлять символы в избранное. Избранный символ будет выделяться в списке символом ★, а его рецепт (если он есть) будет всегда отображаться в подсказке режима композиции.

  • Поддержка модификаций. Возможно добавление, например, собственного «Альтернативного» или TELEX/VNI-подобного режима к уже существующим.

  • И другие, менее значимые возможности…

Подробнее об основных возможностях

Многослойные привязки, они же «Быстрые ключи»

Самое страшное. Их много, невероятно много, и опытный пианист, безусловно, справится с ними. Если верить .HotKeysCount()’у, то их более восьмисот. На каждой клавише может быть до 10–11-ти возможных комбинаций (если не считать комбинации с активным CapsLock за отдельные), но в среднем их около восьми (латинская I в этом чемпион: Ĭ Ï Ī Ĩ Î Ǐ Į İ Í Ì Ȉ).

Демонстрация

Демонстрация

В случае необходимости их можно отключить/включить через RAlt + F1. Состояние сохраняется в файле настроек.

Инструмент создавался под полноразмерную клавиатуру — со стрелками, нампадом и т.д. Это может вызывать неудобства у пользователей других вариантов клавиатур, однако это можно сгладить через пользовательские привязки.

Некоторые комбинации были унаследованы от «Типографской раскладки»:

  • RAlt + Точка (/) — вводит многоточие [ … ],

  • RAlt + 1 | 7 — вводят перевёрнутые восклицательный и вопросительный знак [ ¡ ¿ ],

  • RAlt + 5 — вводит промилле [ ‰ ],

  • RAlt LAlt + 8 — вводит символ бесконечности [ ∞ ] (оригинальную комбинацию занял символ умножения [ × ], а потому для бесконечности в неё был добавлен левый Альт),

  • RAlt *(LShift) + Дефисо-минус — вводят длинное и короткое тире [ — – ],

  • RAlt + Равно — не равно [ ≠ ],

  • RAlt + Пробел — неразрывный пробел [  ].

Комбинации для вставки кавычек унаследованы ввиде Б (<) и Ю (>) как и в «Типографской раскладке», но имеют несколько отличное поведение:

  • RAlt + Б (<) | Ю (>) — вводят [ « » ], если активен русский язык, или [ “ ” ], если активен английский,

  • RAlt LAlt + Б (<) | Ю (>) — тоже, что и предыдущее, но языки поменялись местами,

  • RAlt LShift + Б (<) | Ю (>) — вводят [ „ “ ], если активен русский язык, или [ ‘ ’ ], если активен английский,

  • RAlt RShift + Ё (`) — дополнительная комбинация под [ ’ ] для использования в качестве апострофа.

Примеры уже собственных привязок:

  • RAlt + Клавиши стрелок — [ ←↑↓→ ],

  • RAlt + Пары клавиш стрелок (влево-вверх, вправо-вверх, влево-вниз и т.д.) — [  ],

  • RAlt LShift + Клавиши стрелок — [ ⮌⮍⮏⮎ ],

  • RAlt RShift + Клавиши стрелок влево/вправо — [ ↺↻ ],

  • RAlt RShift + Пробел — круглая шпация [   ],

  • RAlt LShift + Пробел — полукруглая шпация [   ],

  • RAlt LAlt + Пробел — тонкая шпация [    ],

  • RAlt + 9 | 0 — [ ⟨ ⟩ ],

  • RAlt + [ | ] — [ ⁅ ⁆ ],

  • RAlt LAlt LShift RShift + [ | ] — [ 《 》 ],

  • RShift *(CapsLock) + 1 — [ ‽ ⸘ ].

Комбинации, которые не будут отображены в интерфейсе:

  • Shift + 2, 3, 4, 6, 7 отзеркалены для языков на RShift, т.е. при английском LShift + 2 введёт [ @ ] (как обычно), а RShift + 2 — [ " ], на русском — наоборот.

    • 2 (@"), 3 (#№), 4 ($;), 6 (^:), 7 (&?).

  • RShift *(LShift) + Х, Ъ введут скобки [] и {} соответственно.

Ещё есть «Вторичные» и «Третичные ключи», активируемые через RAlt LAlt + F1 и RAlt LAlt + F2. Это дополнительные привязки для символов, которые не влезли в основной пул, но им очень хотелось. Они пришли на замену са́мой первой, отбракованной «механике» инструмента — «Группам активации»: необходимо было нажать комбинацию для активации одной из «групп», а затем ввести символьный ключ желаемого знака.

Отключаются эти ключи повторным нажатием их комбинации, а состояние сохраняется в файле настроек.

Пользовательские привязки

GitHub Gist

Для создания привязок необходимо разместить <ФАЙЛ>.JSON в «DSLKeyPad\User\profile-<ПРОФИЛЬ>\CustomBindings\» со схожей структурой: (см. «Пример.jsonc» в Gist)

Примечание: кодировка файла должна быть UTF-8.

Пользовательские привязки поддерживают следующие форматы: (см. «Форматы.md» в Gist)

И следующие типы значений:

// Обычный текст

"@<ТЕКСТ>"

// Ссылка на запись в библиотеке

"<ИМЯ ЗАПИСИ>::<ВАРИАНТ>×<КОЛИЧЕСТВО>"

Подробнее о формате ссылки на запись см. в блоке о пользовательских рецептах.

Модификаторы: < и > указывают «левый» или «правый», ^, !, + — Ctrl, Alt, Shift. Для RAlt нужно использовать конструкцию <^>!.

После создания пресета его можно будет выбрать в окне настроек либо после перезапуска программы, либо после нажатия кнопки рядом с выпадающим списком в окне настроек.


Режим композиции

Вдохновлён клавишей Compose из Linux и WinCompose. Преобразует последовательность одних символов во что-то другое.

Активируется двойным нажатием RAlt. Ввод пользователя будет отображаться во всплывающей подсказке вместе с предложениями совпадений и списком рецептов избранных символов.

Демонстрация

Демонстрация

Введение «композиции» дало больше простора для ввода. Клавиатура не резиновая и не может уместить бесконечное число привязок. Композиция же принимает любой ввод, в том числе и от «Быстрых ключей», что даёт большу́ю вариативность в рецептах и доступ к бо́льшему количеству символов напрямую с клавиатуры.

Режим композиции срабатывает на первое точное совпадение рецепта. Это и плюс и немного минус — такое поведение не позволит ввести, например, Ǣ из-за автоматического срабатывания AE → Æ. Для решения этой проблемы я ввела режим удержания (клавиша Pause), при котором композиция ждёт нажатия Enter или снятия с удержания.

Помимо режима удержания можно использовать «оператор» гравис [ ` ]. Он не отменяет автоматическое срабатывание, но сохраняет его результат в переменной активной композиции вместо отправки в окно приложения. Это позволяет продолжить последовательности, если есть рецепты, начинающиеся с полученного результата. Ǣ =  A`E → Æ → Æ<МАКРОН>.

Общий перечень клавиш:

  • Enter — подтвердить ввод.

  • Escape — отменить режим композиции.

  • Backspace — стереть последний символ.

  • Insert — вставка содержимого буфера обмена.

  • Pause — переключение удержания.

Операторы

  • Гравис [ ` ] — описан выше.

  • (ЧИСЛО) — при начале ввода с такого оператора результат рецепта будет продублирован указанное число раз, «(5) TH» → «ÞÞÞÞÞ».

  • (~) — при начале ввода с такого оператора можно вводить целые слова, внутри которых будут обработаны рецепты, «(~) T<ЗАПЯТАЯ СНИЗУ>ara Roma<ЦИРКУМФЛЕКС>neasca<КРАТКА>» → «Țara Românească».

  • (ЧИСЛО~) — объединение предыдущих операторов.

  • ## — позволяет предотвратить обработку нежелательных последовательностей, «(~) tho<АКУТ>rr» → «þórr», «(~) t##ho<АКУТ>rr» → «thórr».

Ввод кодовых точек Юникода и Альт-кодов

Режим композиции можно использовать для вставки символов по их кодам. Ввод начинается с U+/Ю+ или A+/А+, а после — значение. Можно указывать множество значений, разделяя их пробелом.

На альт-коды влияет язык активной раскладки: числа 128–255 и 0128–0255 используют страницы 850/Windows−1252 для английской раскладки, 866/Windows−1251 для русской, 737/Windows−1253 для греческой, Windows−1258 для вьетнмаской.

Альт-коды можно вводить в шестнадцатеричном формате: A+0B9 = A+0185 → № (Windows−1251). Для этого ввод должен содержать букву из диапазона A–F. Верхняя граница — A+FF (A+255).

Демонстрация альт-кодов

Демонстрация альт-кодов

Демонстрация Юникода

Демонстрация Юникода


Пользовательские рецепты

Как «вручную», так и через окно интерфейса можно создавать свои рецепты для композиции. Результат может быть сколько угодно объёмным многострочным текстом, но не рекомендую вставлять туда через чур большой текст.

Окно «Мои рецепты»

Окно «Мои рецепты»

Окно создания и редактирования рецепта

Окно создания и редактирования рецепта

При первом запуске создаётся несколько рецептов для демонстрации — шаблон HTML, иероглиф «義», тег <kbd> и эмодзи «».

Основной файл представлен в JSON‐формате, «DSLKeyPad\User\profile-<ПРОФИЛЬ>\CustomRecipes.json». Можно добавлять и дополнительные файлы рецептов в INI (UTF-16 LE) или JSON (UTF-8) форматах, размещая в директории «DSLKeyPad\User\profile-<ПРОФИЛЬ>\CustomRecipes\». Рецепты оттуда будут автоматически загружены при старте программы или при нажатии кнопки обновления в окне «Мои рецепты».

Поддерживается подгрузка последовательностей из файлов формата XCompose. Их небходимо помещать в директорию «DSLKeyPad\User\profile-<ПРОФИЛЬ>\XCompose\». Файл должен заканчиваться расширением «.XCompose»

Примечание: поддерживаются только простые последовательности XCompose, как, например, «<Multi_key> <g> <r> <i> <n> : ""» или «<Multi_key> <U1100> <U1100> : "ᄁ" U1101 # HANGUL CHOSEONG SSANGKIYEOK». При первом запуске в демонстрационных целях по указанному пути создаётся файл «demo.XCompose» с последовательностью «<Multi_key> <0> <0> : "∞"».

Пример дополнительного файла рецептов

Примеры в форматах INI и JSON (GitHub Gist)

Формат ссылки на записи

${<ИМЯ ЗАПИСИ>::<ВАРИАНТ>×<КОЛИЧЕСТВО>} — ссылка, обращающаяся к записи библиотеки, если та существует. Через «::» можно задать «вариацию» (${digit_1} → «1» | ${digit_1::superscript} → «¹»). В конце ссылки через символ «×» можно указать количество повторений вывода записи (${digit_1::superscript×10} → «¹¹¹¹¹¹¹¹¹¹»).

Одной ссылкой можно обратиться сразу к нескольким записям, помещая названия или их часть в \/ конструкцию, например: ${lat_c_let_\b,o,l,d/::bold} → 𝐁𝐎𝐋𝐃, ${\hel,lat/_c_let_a_alpha} → ΑⱭ, ${\nabla,delta,integral,square_root/} → ∇∆∫√.

Ссылки можно использовать и между пользовательскими рецептами для создания зависящих друг от друга рецептов, например:

[white_heart]

name=Белое сердце

recipe=бср|whr

result=

[white_heart_triple]

name=Три белых сердца

recipe=3бср|3whr

result=${white_heart×3} ; вставляет результат первого рецепта трижды

Для <Вариантов> существуют альтернативные формы записи для удобства/сокращения:

  • Bold — полужирный, п, b

  • Italic — курсив, ку, it

  • ItalicBold — курсив полужирный, куп, itb

  • Modifier — верхний индекс, ви, sup

  • Superscript — верхний индекс, ви, sup

  • Subscript — нижний индекс, ни, sub

  • Fraktur — фрактур, ф, f

  • FrakturBold — полужирный фрактур, пф, fb

  • Script — рукописный, р, s

  • ScriptBold — полужирный рукописный, пр, sb

  • DoubleStruck — ds

  • SansSerif — без засечек, бз, ss

  • SansSerifItalic — курсив без засечек, кубз, ssit

  • SansSerifItalicBold — курсив полужирный без засечек, купбз, ssitb

  • SansSerifBold — полужирный без засечек, пбз, ssb

  • Monospace — моноширинный, м, m

  • Fullwidth — полноширинный, пш, fw

  • SmallCapital — капитель, к, sc

  • SmallCapitalModifier — капитель-модификатор, км, scm

  • Small — маленькая, мал, sm

  • Combining — комбинируемый, ко, c

  • Uncombined — некомбинируемый, неко, uc

Для дополнительных файлов рецептов есть возможность добавлять несколько параметров для всех содержащихся в них рецептов (указываются вручную в начале файла):

[options]

; последовательность, устанавливаемая в начало всех рецептов в файле

prefix=<ПЕРФИКС>

; отключает добавление пробела после префикса

no_whitespace=1

; … рецепты

[

 "options": {

  "prefix": <"ПЕРФИКС">,

  "no_whitespace": 1

 },

 // … рецепты

]

Если в файле есть двойные (и более) рецепты (например «лёд|ice»), для них можно задать и подобного вида префиксы (одинарные рецепты всегда берут первый из префиксов):

[options]

prefix=эмодзи|emoji

[recipe_name]

name=Лёд

; потребует ввода «эмодзи лёд» или «emoji ice»

recipe=лёд|ice

result=

PS. Не рекомендую использовать больше 1  500 пользовательских рецептов (что очень легко получить с XCompose-файлами). Сейчас такое может ощутимо замедлить инициализацию программы, но возможно у меня получится это оптимизировать.

XCompose рецепты

XCompose рецепты


Альтернативный ввод

Селектор алтернативного ввода

Селектор алтернативного ввода

Комбинация: LWin + LAlt + S (селектор)

По сути — просто наборы активируемых привязок для целого перечня форм письменности/алфавитов, в основном отличных от латиницы и кириллицы.

Примечание: наборы привязок используют клавиши латиницы и кириллицы, т.е смена «внутренней» раскладки влияет на них.

Некоторые формы письменности активируются парами — одна письменность работает на латинской раскладке, другая на кириллической. В остальном режимы одиночны, работают сразу на нескольких языковых раскладках, но предназначены именно для латинской (в особенности режимы с вводом слогов).

  1. Эллинское письмо (оно же — греческое) — позволяет вводить как символы современного греческого алфавита, так и древнегреческие знаки с добавлением прочих различных символов, относящихся к нему, например:
    αάὰὰἀᾳᾱᾰἅἄἃἂἇἆ ΐ ϐϕϱϖϰϲϵ
    · ; ⸒ ⸏ ⸐ ⸑ ⸎ ⸔ ⸕ ⸓ ⸖ ʹ ͵ ₯

    От стандартной греческой раскладки отличается типичным для английского расположением небуквенных символов и наличием коппы и дигаммы (Ϟ Ϝ) на месте Q W (; ς на греческой раскладке). Здесь знак ς вводится комбинацией LAlt Σ (S).

    Положение привязок не изменяется при смене латинской/кириллической раскладки — для Эллинского письма введена собственная раскладка, однако изменить её нельзя (ну, льзя, просто не посчитала нужным добавить пункт выбора в GUI настроек).

  2. Германские руны — позволяет вводить руны Старшего Футарка, Англосаксонского Футорка, Младшего Футарка, Средневековые руны, «Золотые числа» 17–19 Рунического альманаха (ᛮᛯᛰ), Руны с Ларца Фрэнкса и ещё три руны Толкина за компанию. Ну и значки пунктуации (᛫᛬᛭).

  3. Глаголица — основывается на кириллической раскладке и позволяет вводить как простые буквы глаголицы, так и комбинируемые и соответствующую диакритику. Включается в пару с «Германскими рунами».

  4. И прочие, уже указанные на скриншоте формы письменности и алфавитов: Древнетюркское письмо, Древнепермское письмо (кириллическая раскладка, в паре с Древнетюркским), Секейское письмо, Готское письмо, Этрусское письмо (древнеиталийское, включает символы не только этрусского алфавита), Финикийское письмо, Южноаравийское письмо, Североаравийское письмо, Карийское письмо, Ликийское письмо, Лидийское письмо, Сидетское письмо (на данный момент введён режим и записи библиотеки символов, но официально Сидетская письменность будет введена в Юникод с релизом Unicode 17.0 минимум 9-го сентября, потому пока будут квадратики вместо букв и шрифты найти не получиться), Кипрское слоговое письмо, Тифинаг, Угаритское письмо, Древнеперсидское письмо, Международный фонетический алфавит, Дезеретский алфавит, Алфавит Шоу и режим для ввода математических символов.

Полный охват для каждого режима не гарантирую, но при обнаружении новых или упущенных мной символов — режим будет дополнен.

Вариации глифов

Селектор вариации глифов

Селектор вариации глифов

Комбинация: LWin + LAlt + A (селектор)

Имеет такой же селектор, как у «Альтернативного ввода», но вместо набора привязок указывает программе, какой вариант символа нужно использовать. У записей библиотеки есть атрибут, в котором прописаны варианты — полужирный, курсивный, капитель и т.д. Такие символы не представлены отдельными записями, являясь лишь свойством. Это делает «Вариации глифов» легко совместимыми с фичами, полагающимися на создание привязок.

Если в записи символа отсутствует указанный вариант — будет послан «обычный» символ.

В главной панели под предпросмотром символа будут отображаться первые восемь из доступных вариантов, а справа от предпросмотра активируется кнопка, открывающая GUI для просмотра всех вариантов (которое так же можно открыть через меню трея → Вариации глифов → Панель вариации глифов):

GUI промосмотра вариантов

GUI промосмотра вариантов

TELEX/VNI-подобный ввод

Режимы, основанные на вьетнамских TELEX и VNI раскладках для облегчения ввода, собственно, вьетнамского (с добавлением букв джарайского алфавита) и пиньиня.

Комбинации: RAlt + F2 (Вьетнамский), RAlt + RShift + F2 (Пиньинь) / LWin + LAlt + D (селектор)

Демонстрация

Демонстрация

Для ввода букв с диакритикой необходимо вводить последовательность символов, например: AWS → Ắ (A → Ă → Ắ), A5 → Ẫ, DD→ Đ, BB → Ƀ, UONGW → ƯƠNG, UONG5 → ƯỠNG. Для отмены слипания последовательности можно использовать \, A\W → AW вместо Ă или повторно ввести последний символ (AW → ĂW → AW). Последнюю введённую диакритику можно отменить вводом Z (ǕZ → ÜZ → U).

Можно менять диакритику уже введённого символа, если не перемещать каретку: ẰS → Ắ, ẮA → Ấ, ẤJ → Ậ, ẬR → Ẩ…

Демонстрация

Демонстрация

Перечень символов режимов

  • Tiếng Việt: Á À Ả Ã Ạ Â Ấ Ầ Ẩ Ẫ Ậ Ă Ắ Ằ Ẳ Ẵ Ặ É È Ẻ Ẽ Ẹ Ê Ế Ề Ể Ễ Ệ Í Ì Ỉ Ĩ Ị Ó Ò Ỏ Õ Ọ Ô Ố Ồ Ổ Ỗ Ộ Ơ Ớ Ờ Ở Ỡ Ợ Ú Ù Ủ Ũ Ụ Ư Ứ Ừ Ử Ữ Ự Đ

    • Jơrai: Ĕ Ě Ĭ Ŏ Ǒ Ö Ŭ Ü Ƀ Č Ñ

  • Hànyǔ Pīnyīn: Ā Á À Ǎ Ē É È Ě Ī Í Ì Ǐ Ō Ó Ò Ǒ Ū Ú Ù Ǔ Ü Ǖ Ǘ Ǜ Ǚ

Нюансы

Работает, не так хорошо, как настоящая вьетнамская языковая раскладка — не учитывает контекст поля ввода и перемещение каретки в нём. Для получения контекста необходимо (если не ошибаюсь) лезть в процесс активного окна, и я решила не рисковать — те же античиты в играх такое не оценят, особенно со стороны автохоткея. Было бы не очень, слови пользователь моей программы бан за такое (или я же сама).

Если по какой-то причине «локальный» контекст (видимый во всплывающей подсказке) не совпадает с контекстом поля ввода — его можно сбросить нажатием RCtrl. Так же локальный контекст сбрасывают Enter, Esc, Home, Page Up/Down, Del, клавиши стрелок, ввод пробельных символов.

Ещё один нюанс — не во всех приложениях оно будет работать как задумано из-за отсутствия механизмов IME. Например, в VS Code попытка ввести Ắ приведёт к разными результатам: ĂẮ, AẮ, Ắ, AĂẮ.

В общем, есть что дорабатывать. Если автохоткей позволит (безопасно) использовать средства IME или нечто подобное — эти режимы ждёт видимое улучшение. Я, конечно, спрашивала нейросети про это, но ни одного маломальски рабочего решения они не предложили.


Поиск

Окно ввода для поиска

Окно ввода для поиска

Комбинация: LWin + LAlt + F

Как уже упоминалось — у каждого символа есть набор «тегов», и они могут быть весьма длинными. Например, «строчная буква омега с псили, периспомени и ипогеграммени эллиницы» даст символ «ᾦ».

Вводить полный тег не обязательно — «омег пс пе ип» даст тот же «ᾦ». Однако чем короче запрос, тем менее точный будет результат. Через запятую можно вводить множество запросов:

  • «дез ди, !дез ди, lamb, !lamb» → «𐐔𐐼Λλ»

  • «ref, obe, psms, msps» → «※÷±∓»

Вместо тега можно ввести имя записи, например «hel_c_let_l_lambda» → «Λ».

Можно использовать регулярные выражения, например:

  • «fut.*?\s+\S+al» (ищем тег с любыми символами и пробелами между fut и al) → «ᚺ» (руна Хагалаз), полный тег: «germanic rune elder futhark Hagalaz».

  • «az$» (ищем тег с az в конце) → «ᛞ» (руна Манназ), полный тег: «germanic rune elder futhark Mannaz».

  • «^фра» (ищем тег с фра в начале) → «₣» (Франк).

Поддерживается и указание вариации глифа, добавляя ::<ВАРИАНТ> в конец запроса:

  • «лигатура ae, лигатура ae::капитель, !латин h::фрактур» → «Æᴁ𝔥»

Помимо поиска символов, окно ввода запроса поддерживает вызов некоторых методов/функций:

  • \ или /Reload — перезапускает программу.

  • /Exit — закрывает программу.

  • /ChrLib.Print — создаёт и открывает файл «printed_pairs.html» с перечислением записей локальной библиотеки формата «символ — имя записи».

  • /MyRecipes.Update — ре-инициализирует пользовательские рецепты.

  • %globalInstances.crafter.Start("Compose")% — аналогично RAlt×2 активирует режим композиции…

  • /KbdBinder.Init — ре-инициализирует раскладки и привязки.


Внутренние раскладки клавиатуры

Возможно они могли бы показаться лишними, но они необходимы — привязки прибиваются гвоздями к скан-кодам клавиш (что я посчитала более надёжным, чем к «абстракции» в виде буквы/названия клавиши). Из-за этого переключение системной раскладки не изменит положение привязок программы. Однако в настройках можно выбрать соответствующие внутренние раскладки и тогда привязки будут на корректных местах для отличных от QWERTY/ЙЦУКЕН раскладок.

Для латиницы доступны следующие раскладки: QWERTY, Colemak, Dvorak. Для кириллицы: ЙЦУКЕН, ЙІУКЕН (1907), Диктор. Раскладки могут отличаться от своего оригинала.

Диктор:

  • Для ввода «Ъ» необходимо зажать левый Альт и нажать на «Ь». При этом «Быстрые ключи», назначенные на «Ъ» переходят к «Ь» с добавлением левого Альта в комбинацию (было RAlt *(LShift) + Ъ → ҮҰ, стало RAlt + LAlt *(LShift) + Ь → ҮҰ).

  • Цифровой ряд от ЙЦУКЕН.

ИІУКЕН:

*Добавлена скорее ради забавы.

  • Ввод «-_— –» и «=+≠≈±» перенесён на клавиши «Ъ» и «\» по ЙЦУКЕН.

  • Цифровой ряд от ЙЦУКЕН, за исключением «-» и «=».

Если в программе нет подходящей раскладки — её можно создать самому через <ФАЙЛ>.JSON разметку в «DSLKeyPad\User\profile-<ПРОФИЛЬ>\CustomLayouts\» со следующей структурой: примеры на GitHub Gist.


Модификации

В директории «DSLKeyPad\Mods\» можно размещать сторонние AHK-файлы в качестве «модов» к программе. С помощью модификаций можно значительно кастомизировать программу, например, добавив хоть сотню новых режимов «Альтернативного ввода» или вообще ввести новую, самостоятельную фичу.

[Образец мода]

Для создания мода необходимо создать папку со следующей базовой структурой:

Mods/

└── <ИМЯ МОДА>/

 ├── index.ahk

 ├── options.ini

 └── preview.(ico|jpg|png) (необязательный файл)

Файл index.ahk будет содержать логику мода и к нему можно подключать другие AHK-файлы через #Include (ничем не отличается от независимого AHK-скрипта).

Файл options.ini (UTF−16 LE):

[options]

title=<НАЗВАНИЕ>

version=<ВЕРСИЯ>

type=<ТИП ЗАГРУЗКИ>

author=<АВТОР> ; (опционально добавление @<ССЫЛКА>)

url=<ССЫЛКА НА СТРАНИЦУ МОДА>

description=<ОПИСАНИЕ>

; Локализованные варианты

[ru-RU] ; (или другой код языка)

title=…

author=…

description=…

Тип загрузки может быть pre_init (для загрузки до основной инициализации) или post_init (для загрузки после неё).

Моды автоматически подхватываются. После добавления нового мода следует подождать 5 секунд перед перезапуском программы.

Переключать моды можно через GUI: Меню трея → Модификации.

PS. если необходимо получить путь до папки вашего мода — он автоматически сохраняются в mods[«<ИМЯ МОДА>»].

PSS. моды — не изолированные друг от скрипты, т.е. возможен конфликт в именах переменных, классов.

Окно Модификаций

Окно Модификаций


Главная панель

Скриншот окна

Скриншот окна

Комбинация: LWin + LAlt + Home (или через контекстное меню иконки в трее).

Содержит списки записей символов, их рецепты и комбинации ввода. Также имеется вкладка «Помощь» с поясняющей информацией.


Окно настроек

Скриншот окна

Скриншот окна

Комбинация: RCtrl + F9 (или через контекстное меню иконки в трее).


Контекстное меню трея

Скриншот окна

Скриншот окна


Ограничения и нюансы

  1. Инструмент всё ещё находится в стадии разработки, но уже может быть полноценно использован.

  2. Антиничиты в играх могут триггериться от использования автохоткея, так как немало людей создают на автохоткее разного рода макросы. Перед заходом в любую многопользовательскую игру лучше закрывать все процессы автохоткея.

  3. Потребляет ~140–180 МБ ОЗУ (без учёта модов и пользовательских рецептов). По возможности буду пытаться оптимизировать использование памяти.

  4. Программа плохо совместима с быстрой печатью. Если вам необходима высокая скорость ввода символов — это не тот инструмент, лучше использовать раскладки для отдельных языков.

  5. Программа ограничена работой на английских и русских раскладках. При обнаружении другого языка клавиатуры (например, японский) — все привязки автоматически приостановятся, так как будут мешать этому языку (в примере с японским — невозможность использовать катакану при зажатии LShift). При возврате на английский/русский — автоматически восстановятся.

  6. Не все привязки могут работать на той или иной мембранной клавиатуре. Полноценно проверить работоспособность привязок на механической клавиатуре не удалось (по причине её полурабочего состояния), но она помогла понять, что некоторые привязки не работают из-за основной, мембранной, клавиатуры, а не косяка в коде.

  7. Не во всех приложениях комбинации будут работать или работать стабильно. Например, в Adobe Illustrator что-то вводит символ, что-то нет, а что-то вводит, но он не появляется, пока не нажмёшь на клавишу стрелки.

Из планов на будущее

  1. Продолжать улучшать программу, её логику и возможно вводить какие-то новые фичи.

  2. Сделать страницу с документацией, включающей и гайд для создания модификаций.

  3. Расширить возможности модификаций.

  4. Расширение «Легенд», но своими силами вряд ли получится — это требует лингвистических познаний, коими я не обладаю в достаточной мере.

  5. Расширение библиотеки символов (пропущенными или по мере их ввода в Юникод). Возможно и расширение режимов альтернативного ввода.

  6. Есть мысли перевести интерфейс на веб-рельсы при помощи соответствующей либы и DLL’ки, но это пока имеет низкий приоритет, пусть и результат будет явно симпотичнее, чем с деревянностью местного GUI.


Просто дубль ссылок: GitHub, SourceForge.

PS. Благодарю дочитавших. Надеюсь, что мой инструмент кого-то заинтересует и окажется полезным.

UPD:

15 августа
Вышла версия 0.1.4.3 α:
• Теперь символов 4900+
• Добавлены режимы для Агванского, Пальмирского и Парфянского письма
• Добавлено 16 раскладок для латиницы и 1 для кирилилцы
• Различные фиксы и улучшения

Показать полностью 18
Отличная работа, все прочитано!