10 KiB
10 KiB
KISS Translator シンプル翻訳
シンプルでオープンソースの バイリンガル対照翻訳拡張機能&ユーザースクリプトです。
特徴
- シンプルさを維持
- オープンソース
- 主要なブラウザに対応
- Chrome/Edge
- Firefox
- Kiwi (Android)
- Orion (iOS)
- Safari
- Thunderbird
- 複数の翻訳サービスをサポート
- Google/Microsoft
- Tencent/Volcengine
- OpenAI/Gemini/Claude/Ollama/DeepSeek/OpenRouter
- DeepL/DeepLX/NiuTrans
- AzureAI/CloudflareAI
- Chromeブラウザ内蔵AI翻訳(BuiltinAI)
- 一般的な翻訳シナリオをカバー
- Webページのバイリンガル対照翻訳
- 入力ボックス翻訳
- ショートカットキーで入力ボックス内のテキストを即座に他言語に翻訳
- テキスト選択翻訳
- 任意のページで翻訳ボックスを開き、複数の翻訳サービスで比較翻訳が可能
- 英語辞書翻訳
- 単語のブックマーク
- マウスオーバー翻訳
- YouTube 字幕翻訳
- 任意の翻訳サービスを使用してビデオ字幕を翻訳し、バイリンガル表示をサポート
- 基本的な字幕結合・改行アルゴリズムを内蔵し、翻訳品質を向上
- AIによる改行機能をサポートし、翻訳品質をさらに向上
- 字幕スタイルのカスタマイズ
- 多様な翻訳効果をサポート
- テキスト自動認識と手動ルールの2つのモードをサポート
- テキスト自動認識モードにより、ほとんどのWebサイトでルールを記述しなくても完全な翻訳が可能
- 手動ルールモードで、特定のWebサイトに合わせた最適な最適化が可能
- 翻訳テキストスタイルのカスタマイズ
- リッチテキストの翻訳と表示をサポートし、原文のリンクやその他のテキストスタイルを可能な限り保持
- 翻訳文のみの表示(原文を非表示)をサポート
- テキスト自動認識と手動ルールの2つのモードをサポート
- 翻訳APIの高度な機能
- カスタムAPIにより、理論上あらゆる翻訳インターフェースをサポート
- 翻訳テキストの統合バッチ送信
- AIコンテキスト(会話メモリ)機能をサポートし、翻訳品質を向上
- カスタムAI用語集
- すべてのインターフェースがフックやカスタムパラメータなどの高度な機能をサポート
- クライアント間のデータ同期
- KISS-Worker(cloudflare/docker)
- WebDAV
- カスタム翻訳ルール
- ルールの購読/ルール共有
- カスタム専門用語
- カスタムショートカットキー
Alt+Q翻訳をオンAlt+Cスタイル切り替えAlt+K設定ポップアップを開くAlt+S翻訳ポップアップを開く/選択テキストを翻訳Alt+O設定ページを開くAlt+I入力ボックス翻訳
インストール
注:以下の理由により、ブラウザ拡張機能の使用を優先することをお勧めします
- ブラウザ拡張機能の方が機能が完全です(ローカル言語認識、右クリックメニューなど)
- ユーザースクリプトはより多くの問題(クロスドメイン問題、スクリプトの競合など)に遭遇する可能性があります
- ブラウザ拡張機能
- ユーザースクリプト
- Chrome/Edge/Firefox (Tampermonkey/Violentmonkey) インストールリンク
- iOS Safari (Userscripts Safari) インストールリンク
関連プロジェクト
- データ同期サービス: https://github.com/fishjar/kiss-worker
- 本プロジェクトのデータ同期サービスとして使用できます。
- 個人のプライベートなルールリストの共有にも使用できます。
- セルフホスト、セルフマネジメント、データはプライベート。
- コミュニティ購読ルール: https://github.com/fishjar/kiss-rules
- コミュニティによってメンテナンスされた、最新かつ最も完全な購読ルールリストを提供します。
- ルール関連の問題についての助けを求める。
よくある質問(FAQ)
ショートカットキーの設定方法
拡張機能の管理ページで設定します。例:
- chrome chrome://extensions/shortcuts
- firefox about:addons
ルール設定の優先順位は?
個人ルール > 購読ルール > グローバルルール
グローバルルールの優先順位は最も低いですが、フォールバックルールとして非常に重要です。
API(Ollamaなど)のテストに失敗する
APIテストの失敗には、一般的に以下の原因が考えられます:
- アドレスが間違っている:
- 例えば
OllamaにはネイティブAPIアドレスとOpenai互換のアドレスがありますが、本プラグインは現在、Openai互換アドレスをサポートしており、OllamaネイティブAPIアドレスはサポートしていません
- 例えば
- 一部のAIモデルが統合翻訳をサポートしていない:
- この場合、統合翻訳を無効にするか、カスタムAPIを使用して対応できます。
- または、カスタムAPIを使用して対応します。詳細はカスタムAPIサンプルドキュメントを参照してください
- 一部のAIモデルでパラメータが一致しない:
- 例えば
GeminiのネイティブAPIはパラメータの不一致が大きく、一部のバージョンのモデルが特定のパラメータをサポートしていないためエラーが返されることがあります。 - この場合、
Hookを使用してリクエストbodyを変更するか、Gemini2(Openai互換アドレス) に切り替えることができます
- 例えば
- サーバーのクロスドメイン制限によりアクセスが拒否され、403エラーが返される:
- 例えば
Ollamaを起動する際に、環境変数OLLAMA_ORIGINS=*を追加する必要があります。参考:https://github.com/fishjar/kiss-translator/issues/174
- 例えば
入力したAPIがユーザースクリプトで使用できない
ユーザースクリプトは、リクエストを送信するためにドメインのホワイトリストを追加する必要があります。
カスタムAPIのhook関数の設定方法
カスタムAPI機能は非常に強力で柔軟性があり、理論的にはどんな翻訳APIにも接続できます。
サンプル参照: custom-api_v2.md
ユーザースクリプトの設定ページに直接アクセスする方法
設定ページアドレス: https://fishjar.github.io/kiss-translator/options.html
今後の計画
本プロジェクトは余暇に開発しており、厳密なタイムスケジュールはありません。コミュニティの共同構築を歓迎します。以下は初期段階の機能の方向性です:
- テキストの統合送信:リクエスト戦略を最適化し、翻訳APIの呼び出し回数を減らし、パフォーマンスを向上させます。
- リッチテキスト翻訳の強化:より複雑なページ構造やリッチテキストコンテンツの正確な翻訳をサポートします。
- カスタム/AI APIの強化:コンテキストメモリ、複数ラウンドの対話など、高度なAI機能をサポートします。
- 英語辞書のフォールバックメカニズム:翻訳サービスが利用できない場合、他の辞書に切り替えるか、ローカル辞書での検索にフォールバックします。
- YouTube字幕サポートの最適化:ストリーミング字幕の結合と翻訳体験を改善し、途切れを減らします。
- ルール共同構築メカニズムのアップグレード:より柔軟なルールの共有、バージョン管理、コミュニティレビュープロセスを導入します。
特定の方向に興味がある場合は、Issues で議論したり、PRを送信したりすることを歓迎します!
開発ガイド
git clone [https://github.com/fishjar/kiss-translator.git](https://github.com/fishjar/kiss-translator.git)
cd kiss-translator
git checkout dev # PRを送信する場合はdevブランチにプッシュすることをお勧めします
pnpm install
pnpm build