[{"data":1,"prerenderedAt":3694},["ShallowReactive",2],{"blog-\u002Fblog\u002Fvideo-compress-intro":3,"blog-list-ja":277},{"id":4,"title":5,"author":6,"body":7,"category":259,"coverImage":260,"description":261,"draft":262,"extension":263,"locale":264,"meta":265,"navigation":266,"noindex":262,"path":267,"publishedAt":268,"seo":269,"slug":270,"stem":271,"tags":272,"updatedAt":268,"__hash__":276},"blog\u002Fblog\u002Fvideo-compress-intro.md","動画をブラウザ内で圧縮する — \u002Ftools\u002Fvideo-compress の思想と使い方","Zerosend Editorial",{"type":8,"value":9,"toc":244},"minimark",[10,14,27,31,34,42,53,56,59,82,86,113,116,120,123,127,138,174,177,181,188,191,197,203,209,215,218,241],[11,12,13],"p",{},"打ち合わせ動画、商品撮影、画面録画、子供の運動会。日常で動画を扱う場面は増える一方で、SNS やメッセンジャーのサイズ制限、メールの添付上限、サーバーのストレージコストといった現実的な壁にぶつかります。",[11,15,16,17,26],{},"Zerosend は ",[18,19,21,22,25],"a",{"href":20},"\u002Ftools\u002Fvideo-compress","動画圧縮ツール (",[23,24,20],"code",{},")"," を、この「軽くしたいだけなのに、動画を他人のサーバーに預ける必要はない」という素朴な違和感を起点に作りました。この記事では、なぜ作ったのか、どう使うのか、裏で何が起きているのかを Zerosend 編集部が整理します。",[28,29,30],"h2",{"id":30},"なぜブラウザ内で動画を圧縮するのか",[11,32,33],{},"動画は個人情報そのものです。顔・声・背景・位置情報、ときには画面録画の中にパスワードや顧客名まで写り込みます。これをオンラインの圧縮サービスにアップロードするということは、事実上その内容を一度他人のサーバーに預けることを意味します。",[11,35,36,37,41],{},"多くのサービスは「一定時間で自動削除」を謳いますが、",[38,39,40],"strong",{},"その削除は利用者から検証できません","。削除完了のスクリーンショットを送ってくれるわけでもなく、ログがどこまで残るかも不透明です。未公開の企画映像や社内会議の録画を、無料ツールに放り込むことに抵抗を感じたことがある人は多いはずです。",[11,43,44,45,48,49,52],{},"Zerosend は逆のアプローチを取ります。",[38,46,47],{},"動画ファイルを最初から外に出さない","。処理はすべて、あなたがいま開いているこのブラウザ、ローカル端末の CPU と GPU の中だけで完結します。DevTools の Network タブを開いたまま圧縮を実行すれば、動画そのものがアップロードされていないことを自分の目で確認できます。信用してもらう代わりに、",[38,50,51],{},"検証可能にする"," — これが Zerosend の基本方針です。",[28,54,55],{"id":55},"使い方",[11,57,58],{},"操作はシンプルです。",[60,61,62,70,73,76,79],"ol",{},[63,64,65,69],"li",{},[18,66,67],{"href":20},[23,68,20],{}," を開く",[63,71,72],{},"画面中央のドロップゾーンに動画ファイルをドラッグ&ドロップ、またはクリックして選択 (MP4 \u002F WebM \u002F MOV、最大 500MB)",[63,74,75],{},"圧縮強度 (CRF) と解像度を選ぶ",[63,77,78],{},"「圧縮を開始する」をクリック",[63,80,81],{},"処理が終わると「処理完了。あなたのファイルは外に出ていません。」と表示され、ダウンロードボタンから結果を保存できる",[83,84,85],"h3",{"id":85},"設定の目安",[87,88,89,95,101,107],"ul",{},[63,90,91,94],{},[38,92,93],{},"高画質 (CRF 23)",": 画質維持を最優先。削減率は 10〜30% 程度。保存用のマスター映像向け",[63,96,97,100],{},[38,98,99],{},"標準 (CRF 28)",": 視覚的な劣化は軽微。削減率 40〜70%。ウェブ掲載・SNS 共有に",[63,102,103,106],{},[38,104,105],{},"小さめ (CRF 32)",": 多少ぼやけるが容量優先。チャット添付・LINE・メール向け",[63,108,109,112],{},[38,110,111],{},"最小 (CRF 36)",": 輪郭が甘くなる。品質より「とにかく送れる」が最優先なとき",[11,114,115],{},"解像度は 100 \u002F 75 \u002F 50% から選べます。1080p の素材を 75% にすると、CRF を 1〜2 下げるより確実にサイズが落ちます。",[28,117,119],{"id":118},"仕組み-二段構えのエンジン","仕組み — 二段構えのエンジン",[11,121,122],{},"Zerosend の動画圧縮は、単一のエンジンに依存していません。ブラウザの能力を見て、もっとも速い経路を自動で選びます。",[83,124,126],{"id":125},"_1-webcodecs-高速パス","1. WebCodecs (高速パス)",[11,128,129,130,133,134,137],{},"Chrome \u002F Edge \u002F 最近の Safari には ",[23,131,132],{},"WebCodecs"," API が実装されており、",[38,135,136],{},"GPU 支援の H.264 エンコーダ","をブラウザから直接呼び出せます。Zerosend は対応環境では次のパイプラインで処理します。",[87,139,140,146,152,159,165,168],{},[63,141,142,145],{},[23,143,144],{},"mp4box.js"," で MP4 ファイルを demux",[63,147,148,151],{},[23,149,150],{},"VideoDecoder"," でフレームを復号 (ハードウェアアクセラレーション)",[63,153,154,155,158],{},"必要なら ",[23,156,157],{},"OffscreenCanvas"," でリサイズ",[63,160,161,164],{},[23,162,163],{},"VideoEncoder"," で H.264 に再エンコード (GPU)",[63,166,167],{},"音声はロスレスコピー (AAC のチャンクをそのまま維持)",[63,169,170,173],{},[23,171,172],{},"mp4-muxer"," で MP4 に mux し、Blob として出力",[11,175,176],{},"これにより、数百 MB の動画も数十秒で処理できます。処理後の結果カードに「エンジン: webcodecs」と表示されれば、このパスが走っています。",[83,178,180],{"id":179},"_2-ffmpegwasm-フォールバック","2. ffmpeg.wasm (フォールバック)",[11,182,183,184,187],{},"WebCodecs が未対応のブラウザ、HEVC などの特殊なコーデック入力、mp4box が parse できない特殊コンテナのときは、自動的に ",[23,185,186],{},"ffmpeg.wasm"," に切り替わります。こちらは完全に CPU で処理するため速度は落ちますが、対応できるフォーマットの幅が段違いに広いのが強みです。ffmpeg-core は Cloudflare R2 から、同一オリジンのパスを経由して 32MB の WASM を取得します。初回のみ時間がかかりますが、2 回目以降はブラウザのキャッシュから復元されます。",[28,189,190],{"id":190},"よくある質問",[11,192,193,196],{},[38,194,195],{},"Q. 処理中にインターネット接続が切れたら？","\nA. 動画本体の送受信は発生しないため、圧縮処理自体は継続します。エンジン (ffmpeg.wasm) が未ロードの状態だと初回ダウンロードで失敗しますが、一度読み込んだあとはオフラインでも動作します。",[11,198,199,202],{},[38,200,201],{},"Q. 結果のファイルはどこに保存されますか？","\nA. ダウンロードボタンを押したときのブラウザの保存先です。サーバーには何も残りません。結果ファイルはタブを閉じるとメモリから消えます。",[11,204,205,208],{},[38,206,207],{},"Q. 画質が思ったより落ちます。","\nA. CRF を下げる (例: 28 → 23)、または解像度の縮小をやめる (50% → 100%) と改善します。素材が 4K なら、100% のまま CRF を下げるより 75% + CRF 25 の方が視覚的なバランスが取れやすいです。",[11,210,211,214],{},[38,212,213],{},"Q. iPhone で撮った MOV も処理できますか？","\nA. はい。HEVC (H.265) の場合は ffmpeg.wasm 側のフォールバックに回るため時間がかかりますが、H.264 にトランスコードされた MP4 として出力されます。",[28,216,217],{"id":217},"関連ツール",[87,219,220,227,234],{},[63,221,222,226],{},[18,223,225],{"href":224},"\u002Ftools\u002Fvideo-to-gif","動画 → GIF"," — SNS の表紙やドキュメント挿入に",[63,228,229,233],{},[18,230,232],{"href":231},"\u002Ftools\u002Fvideo-trim","動画トリミング"," — 必要な区間だけ切り出してから圧縮すると効率的",[63,235,236,240],{},[18,237,239],{"href":238},"\u002Ftools\u002Fvideo-convert","動画形式変換"," — MOV \u002F WebM → MP4 など",[11,242,243],{},"Zerosend は「日常のちょっとした加工を、あなたの端末で完結させる」ことに徹したツール集です。動画の中身があなたの手元から離れないことを、DevTools で自分の目で確かめてから使ってみてください。",{"title":245,"searchDepth":246,"depth":246,"links":247},"",2,[248,249,253,257,258],{"id":30,"depth":246,"text":30},{"id":55,"depth":246,"text":55,"children":250},[251],{"id":85,"depth":252,"text":85},3,{"id":118,"depth":246,"text":119,"children":254},[255,256],{"id":125,"depth":252,"text":126},{"id":179,"depth":252,"text":180},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"tech",null,"Zerosend の動画圧縮ツールは、動画ファイルをサーバーに送らずブラウザ内で再エンコードしてサイズを削減します。WebCodecs で GPU 支援、未対応環境では ffmpeg.wasm にフォールバック。設計思想と使い方、仕組みを Zerosend 編集部が解説します。",false,"md","ja",{},true,"\u002Fblog\u002Fvideo-compress-intro","2026-04-20",{"title":5,"description":261},"video-compress-intro","blog\u002Fvideo-compress-intro",[273,274,132,275],"動画","圧縮","ツール","ccJoeP9JV0Bqlfhgq6LpUwyaFfFS7koHd_Uj655guv8",[278,487,665,814,990,1158,1330,1516,1683,1830,1997,2166,2340,2505,2689,2851,3015,3191,3332,3478,3559],{"id":279,"title":280,"author":6,"body":281,"category":259,"coverImage":260,"description":477,"draft":262,"extension":263,"locale":264,"meta":478,"navigation":266,"noindex":262,"path":479,"publishedAt":268,"seo":480,"slug":481,"stem":482,"tags":483,"updatedAt":268,"__hash__":486},"blog\u002Fblog\u002Faudio-convert-intro.md","音声形式を変換する — \u002Ftools\u002Faudio-convert の思想と使い方",{"type":8,"value":282,"toc":467},[283,286,293,296,303,306,308,328,331,357,360,386,389,392,417,420,422,428,434,440,446,448],[11,284,285],{},"取材の録音を MP3 に揃えたい、古い WAV ファイルを容量節約のため M4A に変えたい、ポッドキャスト配信用の形式に統一したい。音声ファイルの形式変換は、取材者・編集者・音楽制作者が日常的に行う作業です。",[11,287,288,292],{},[18,289,291],{"href":290},"\u002Ftools\u002Faudio-convert","Zerosend の音声形式変換ツール"," は、この作業をブラウザ内で完結させます。",[28,294,295],{"id":295},"なぜブラウザ内で変換するのか",[11,297,298,299,302],{},"録音された音声は、",[38,300,301],{},"発話の中身そのもの","を情報として持ちます。インタビュー対象者の声、打ち合わせでの発言、取材源の証言。これらを無料のオンライン変換サービスに預けることは、発話内容そのものを第三者のサーバーに預けることに等しいものです。",[11,304,305],{},"Zerosend は変換処理をローカルで行うため、音声ファイルが一切外に出ません。取材ソースの保護や NDA 下の音源加工でも安全に使えます。",[28,307,55],{"id":55},[60,309,310,316,319,322,325],{},[63,311,312,69],{},[18,313,314],{"href":290},[23,315,290],{},[63,317,318],{},"音声ファイルをドラッグ&ドロップ (複数可)",[63,320,321],{},"出力形式 (MP3 \u002F WAV \u002F M4A \u002F OGG) とビットレートを選択",[63,323,324],{},"「変換を開始する」をクリック",[63,326,327],{},"結果を ZIP でダウンロード",[28,329,330],{"id":330},"形式の選び方",[87,332,333,339,345,351],{},[63,334,335,338],{},[38,336,337],{},"MP3",": 最も汎用。ポッドキャスト・配信・共有の標準",[63,340,341,344],{},[38,342,343],{},"WAV",": 可逆 (ロスレス)。編集中のマスター音源・音楽制作用",[63,346,347,350],{},[38,348,349],{},"M4A (AAC)",": MP3 より圧縮効率が良い。iOS 環境で標準",[63,352,353,356],{},[38,354,355],{},"OGG (Vorbis)",": オープン形式。ゲーム・一部ブラウザで効率重視",[83,358,359],{"id":359},"ビットレートの目安",[87,361,362,368,374,380],{},[63,363,364,367],{},[38,365,366],{},"320 kbps",": 音質最優先 (MP3 の実用上限)",[63,369,370,373],{},[38,371,372],{},"192 kbps",": 標準品質。一般向け音声の定番",[63,375,376,379],{},[38,377,378],{},"128 kbps",": 容量優先。音声解説・ポッドキャスト",[63,381,382,385],{},[38,383,384],{},"96 kbps 以下",": 会話のみの録音など、音質より軽さ",[28,387,388],{"id":388},"仕組み",[11,390,391],{},"ffmpeg.wasm を使って再エンコードしています。",[87,393,394,397,411,414],{},[63,395,396],{},"入力音声を ffmpeg FS に書き込み",[63,398,399,400,403,404,403,407,410],{},"出力形式に応じたエンコーダ (",[23,401,402],{},"libmp3lame",", ",[23,405,406],{},"aac",[23,408,409],{},"libvorbis"," など) を指定",[63,412,413],{},"ビットレート・チャンネル数・サンプリングレートを設定",[63,415,416],{},"出力 Blob を生成してダウンロード",[11,418,419],{},"メタデータ (タイトル・アーティスト) は極力引き継ぎます。",[28,421,190],{"id":190},[11,423,424,427],{},[38,425,426],{},"Q. 可逆 → 非可逆 (WAV → MP3) と 非可逆 → 非可逆 (MP3 → M4A) の違いは？","\nA. 非可逆 → 非可逆は二重に圧縮されるため音質がさらに劣化します。可能な限りマスター音源 (WAV) から目的形式に直接変換するのがお勧めです。",[11,429,430,433],{},[38,431,432],{},"Q. 複数ファイルのバッチ変換は？","\nA. 対応しています。10〜20 ファイル程度を 1 バッチで処理するのが現実的です。",[11,435,436,439],{},[38,437,438],{},"Q. 動画から音声だけ抜き出したい","\nA. 動画ファイルを入力すれば音声トラックを抽出して指定形式で書き出します。",[11,441,442,445],{},[38,443,444],{},"Q. ビットレートを自由に指定できる？","\nA. プリセットから選ぶ方式です。細かい制御が必要なら別途専門ツールをご検討ください。",[28,447,217],{"id":217},[87,449,450,457,462],{},[63,451,452,456],{},[18,453,455],{"href":454},"\u002Ftools\u002Faudio-trim","音声トリミング"," — 変換前後の区間切り出し",[63,458,459,461],{},[18,460,239],{"href":238}," — 動画側の形式変換",[63,463,464,466],{},[18,465,232],{"href":231}," — 音声抽出前の動画整形",{"title":245,"searchDepth":246,"depth":246,"links":468},[469,470,471,474,475,476],{"id":295,"depth":246,"text":295},{"id":55,"depth":246,"text":55},{"id":330,"depth":246,"text":330,"children":472},[473],{"id":359,"depth":252,"text":359},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の音声形式変換ツールは、MP3 \u002F WAV \u002F M4A \u002F FLAC \u002F OGG などをサーバーに送らずブラウザ内で相互変換します。録音インタビューや音源ファイルの形式統一に。Zerosend 編集部が解説。",{},"\u002Fblog\u002Faudio-convert-intro",{"title":280,"description":477},"audio-convert-intro","blog\u002Faudio-convert-intro",[484,485,275],"音声","変換","kgzSn9tpEqJdQkfZCQKjEEBSxKOoB_cm7dQc9t69f6s",{"id":488,"title":489,"author":6,"body":490,"category":259,"coverImage":260,"description":656,"draft":262,"extension":263,"locale":264,"meta":657,"navigation":266,"noindex":262,"path":658,"publishedAt":268,"seo":659,"slug":660,"stem":661,"tags":662,"updatedAt":268,"__hash__":664},"blog\u002Fblog\u002Faudio-trim-intro.md","音声をトリミング (切り出し) する — \u002Ftools\u002Faudio-trim の思想と使い方",{"type":8,"value":491,"toc":648},[492,495,500,503,506,513,515,535,537,548,561,568,571,597,599,605,611,617,629,631],[11,493,494],{},"60 分のインタビューから引用したい 30 秒を抜き出したい、会議録音の不要な冒頭\u002F末尾をカットしたい、ポッドキャスト素材のつなぎ目を整えたい。音声のトリミングは、録音後の編集で最初に行う作業です。",[11,496,497,292],{},[18,498,499],{"href":454},"Zerosend の音声トリミングツール",[28,501,502],{"id":502},"なぜブラウザ内でトリミングするのか",[11,504,505],{},"音声ファイルには発話内容そのものが記録されています。インタビュー、取材、商談、カウンセリング、医療相談。どれも機密性が高く、少なくとも当事者以外に聞かれることを想定していない音声です。",[11,507,508,509,512],{},"「一部だけ切り出したい」という作業でも、オンラインツールに預けると",[38,510,511],{},"入力した音声全体","が相手に渡ります。Zerosend はトリミング処理をローカルで行うため、アップロードそのものが発生せず、音源全体の機密が守られます。",[28,514,55],{"id":55},[60,516,517,523,526,529,532],{},[63,518,519,69],{},[18,520,521],{"href":454},[23,522,454],{},[63,524,525],{},"音声ファイルをドラッグ&ドロップ",[63,527,528],{},"開始時刻・終了時刻を指定",[63,530,531],{},"「トリミングを開始する」をクリック",[63,533,534],{},"切り出された音声をダウンロード",[28,536,388],{"id":388},[11,538,539,540,543,544,547],{},"ffmpeg.wasm の ",[23,541,542],{},"-ss"," \u002F ",[23,545,546],{},"-to"," オプションで指定区間を抽出します。",[87,549,550,552,558],{},[63,551,396],{},[63,553,554,557],{},[23,555,556],{},"-ss \u003Cstart> -i input -to \u003Cend> -c copy output"," でロスレス抽出",[63,559,560],{},"再エンコードなしで切り出すため処理が速く音質劣化もない",[11,562,563,564,567],{},"入力がどの形式であっても、基本的には同じ形式で書き出されます。形式を変えたいときは ",[18,565,566],{"href":290},"音声形式変換"," と組み合わせてください。",[28,569,570],{"id":570},"使いどころ",[87,572,573,579,585,591],{},[63,574,575,578],{},[38,576,577],{},"インタビューの引用",": 60 分音源から 30 秒の引用箇所を切り出す",[63,580,581,584],{},[38,582,583],{},"不要区間の除去",": 録音冒頭の環境音や末尾の雑音をカット",[63,586,587,590],{},[38,588,589],{},"ポッドキャスト編集",": 冗長な「えー」「あのー」を含む区間を削除 (1 区間ずつ)",[63,592,593,596],{},[38,594,595],{},"会議議事録の根拠音声",": 要旨に関連する数分の根拠区間を抜き出す",[28,598,190],{"id":190},[11,600,601,604],{},[38,602,603],{},"Q. 複数区間を切り出して連結できる？","\nA. 現状は 1 区間のみです。複数区間を抽出したい場合は 1 つずつ切り出してから別途連結してください。",[11,606,607,610],{},[38,608,609],{},"Q. 音質は落ちますか？","\nA. 再エンコードしないため、元音質がそのまま保持されます。",[11,612,613,616],{},[38,614,615],{},"Q. フェードイン\u002Fフェードアウトを追加できますか？","\nA. 現状は非対応です。必要なら切り出した音声を別の編集ツールで処理してください。",[11,618,619,622,623,625,626,628],{},[38,620,621],{},"Q. 動画ファイルから音声部分だけ切り出したい","\nA. 動画ファイルを入力して ",[18,624,566],{"href":290}," を使うと、動画の音声トラックを指定形式で抽出できます。トリミングしたい区間があるなら、まず ",[18,627,232],{"href":231}," で区間抽出 → 音声形式変換、の順がお勧めです。",[28,630,217],{"id":217},[87,632,633,638,643],{},[63,634,635,637],{},[18,636,566],{"href":290}," — トリミング後に形式を変えたいとき",[63,639,640,642],{},[18,641,232],{"href":231}," — 映像付きの区間抽出",[63,644,645,647],{},[18,646,239],{"href":238}," — 動画側の処理",{"title":245,"searchDepth":246,"depth":246,"links":649},[650,651,652,653,654,655],{"id":502,"depth":246,"text":502},{"id":55,"depth":246,"text":55},{"id":388,"depth":246,"text":388},{"id":570,"depth":246,"text":570},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の音声トリミングツールは、音声ファイルをサーバーに送らずブラウザ内で任意の区間だけ切り出します。長尺インタビュー・会議録音・ポッドキャスト素材の整形に。Zerosend 編集部が解説。",{},"\u002Fblog\u002Faudio-trim-intro",{"title":489,"description":656},"audio-trim-intro","blog\u002Faudio-trim-intro",[484,663,275],"トリミング","hFWCw0D3du7ZQd9d2boBEpRhRBLppxa1qHPrZvJ6vsM",{"id":666,"title":667,"author":6,"body":668,"category":259,"coverImage":260,"description":803,"draft":262,"extension":263,"locale":264,"meta":804,"navigation":266,"noindex":262,"path":805,"publishedAt":268,"seo":806,"slug":807,"stem":808,"tags":809,"updatedAt":268,"__hash__":813},"blog\u002Fblog\u002Fheic-to-jpg-intro.md","HEIC を JPG に変換する — \u002Ftools\u002Fheic-to-jpg の思想と使い方",{"type":8,"value":669,"toc":796},[670,673,680,684,687,690,692,710,712,722,742,745,747,753,759,765,771,773],[11,671,672],{},"iPhone で撮影した写真を PC や同僚に送ったら「開けません」と言われた経験はありませんか。iPhone の標準形式 HEIC (High Efficiency Image Container) は、Apple エコシステム外では互換性が限定的です。Windows 10 以降はアドオンが必要、画像編集ソフトも対応が遅れがちです。",[11,674,675,679],{},[18,676,678],{"href":677},"\u002Ftools\u002Fheic-to-jpg","Zerosend の HEIC → JPG 変換ツール"," は、この問題をブラウザ内で解決します。",[28,681,683],{"id":682},"なぜブラウザ内で-heic-を変換するのか","なぜブラウザ内で HEIC を変換するのか",[11,685,686],{},"iPhone で撮った写真は、個人・家族・仕事の私的情景を含みがちです。顔、家の中、位置情報、撮影日時。これらを無料のオンライン変換サービスにアップロードすることは、事実上それらの情報を第三者に預けることを意味します。",[11,688,689],{},"Zerosend は、HEIC のデコードから JPG の書き出しまで、すべてブラウザ内で行います。写真自体が外に出ないため、NDA 下の撮影素材や家族の写真でも安心して使えます。",[28,691,55],{"id":55},[60,693,694,700,703,706,708],{},[63,695,696,69],{},[18,697,698],{"href":677},[23,699,677],{},[63,701,702],{},"HEIC \u002F HEIF 形式の画像をドラッグ&ドロップ (複数可)",[63,704,705],{},"品質 (JPG の圧縮率) を選択",[63,707,324],{},[63,709,327],{},[28,711,388],{"id":388},[11,713,714,715,718,719,721],{},"HEIC のデコードはブラウザ標準ではまだ実装されていないため、",[23,716,717],{},"heic2any"," ライブラリを読み込んで使っています。",[23,720,717],{}," は libheif を WebAssembly 化したもので、ブラウザ内で HEIC を Blob として展開できます。",[87,723,724,727,732,735],{},[63,725,726],{},"HEIC ファイルを ArrayBuffer として読み込み",[63,728,729,731],{},[23,730,717],{}," で JPEG Blob に変換 (libheif の WASM が実行される)",[63,733,734],{},"必要なら Canvas 経由で品質を再指定",[63,736,737,738,741],{},"元のファイル名を保持したまま ",[23,739,740],{},".jpg"," 拡張子で書き出し",[11,743,744],{},"初回のみ libheif の WASM (約 2MB) をダウンロードするため少し待ち時間がありますが、2 回目以降はキャッシュから即時起動します。",[28,746,190],{"id":190},[11,748,749,752],{},[38,750,751],{},"Q. HEIC と HEIF の違いは？","\nA. HEIF がコンテナフォーマットの総称で、HEIC はその中で HEVC (H.265) でエンコードされた静止画を指します。本ツールは両方対応しています。",[11,754,755,758],{},[38,756,757],{},"Q. Live Photo はどうなりますか？","\nA. 静止画部分のみが JPG として書き出されます。動画部分は含まれません。動画も抽出したい場合は別途 iPhone 側で「書き出す > 現状のまま」を使ってください。",[11,760,761,764],{},[38,762,763],{},"Q. EXIF (撮影日時・位置情報) は引き継がれますか？","\nA. 一部情報は失われます。位置情報のプライバシー観点ではむしろ利点です。",[11,766,767,770],{},[38,768,769],{},"Q. 複数ファイルまとめて変換できますか？","\nA. はい。ZIP で一括ダウンロードできます。数十枚程度までは快適に処理できます。",[28,772,217],{"id":217},[87,774,775,782,789],{},[63,776,777,781],{},[18,778,780],{"href":779},"\u002Ftools\u002Fimage-compress","画像圧縮"," — JPG 変換後にさらに軽くしたいとき",[63,783,784,788],{},[18,785,787],{"href":786},"\u002Ftools\u002Fimage-resize","画像リサイズ"," — 送信前に寸法も揃える",[63,790,791,795],{},[18,792,794],{"href":793},"\u002Ftools\u002Fimage-convert","画像形式変換"," — JPG \u002F PNG \u002F WebP の相互変換",{"title":245,"searchDepth":246,"depth":246,"links":797},[798,799,800,801,802],{"id":682,"depth":246,"text":683},{"id":55,"depth":246,"text":55},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"iPhone で撮った HEIC 画像を Windows \u002F Android や古いシステムで開けるよう JPG に変換するツール。サーバーに送らずブラウザ内で変換する仕組みと注意点を Zerosend 編集部が解説。",{},"\u002Fblog\u002Fheic-to-jpg-intro",{"title":667,"description":803},"heic-to-jpg-intro","blog\u002Fheic-to-jpg-intro",[810,811,812,275],"HEIC","画像","iPhone","0cpdD3jngClgWGSDf6EYR2UtF-Zz0rDNW4WhdyYyONM",{"id":815,"title":816,"author":6,"body":817,"category":259,"coverImage":260,"description":982,"draft":262,"extension":263,"locale":264,"meta":983,"navigation":266,"noindex":262,"path":984,"publishedAt":268,"seo":985,"slug":986,"stem":987,"tags":988,"updatedAt":268,"__hash__":989},"blog\u002Fblog\u002Fimage-convert-intro.md","画像形式変換をブラウザ内で — \u002Ftools\u002Fimage-convert の思想と使い方",{"type":8,"value":818,"toc":974},[819,822,828,831,838,841,843,862,864,890,897,899,906,928,935,937,943,949,955,957],[11,820,821],{},"「PNG で貰ったロゴを JPEG にしたい」「iPhone で撮った HEIC を JPG で送りたい」「サイト表示を速くするために WebP に揃えたい」。画像の形式変換は地味ですが発生頻度の高い作業です。",[11,823,824,827],{},[18,825,826],{"href":793},"Zerosend の画像形式変換ツール"," は、この日常作業をブラウザ内で完結させます。一度も外に出さずに、あなたの端末だけで別形式に書き出します。",[28,829,830],{"id":830},"なぜブラウザ内で形式変換するのか",[11,832,833,834,837],{},"画像変換サービスの多くは、アップロード → サーバーで変換 → ダウンロード という流れです。社員写真、契約書のスキャン、製品デザイン案。",[38,835,836],{},"中身を見られたくない画像ほど、オンライン変換ツールに投げづらい","のが現実です。",[11,839,840],{},"Zerosend は、変換処理そのものがブラウザ内で完結するため、機密性の高い素材でもそのまま使えます。DevTools の Network タブを開いたまま変換しても、画像本体がアップロードされていないことを自分で確認できます。",[28,842,55],{"id":55},[60,844,845,851,854,857,859],{},[63,846,847,69],{},[18,848,849],{"href":793},[23,850,793],{},[63,852,853],{},"画像をドラッグ&ドロップ (複数可)",[63,855,856],{},"出力形式 (JPEG \u002F PNG \u002F WebP) と品質を選択",[63,858,324],{},[63,860,861],{},"結果を ZIP でまとめてダウンロード",[28,863,330],{"id":330},[87,865,866,872,878,884],{},[63,867,868,871],{},[38,869,870],{},"JPEG",": 写真・背景画像。透過不要。古いブラウザ\u002Fアプリ互換性が最重要なら",[63,873,874,877],{},[38,875,876],{},"PNG",": ロゴ・UI パーツ・透過必要なグラフィック。可逆圧縮",[63,879,880,883],{},[38,881,882],{},"WebP",": 汎用。JPEG より 25〜35% 小さくなり、透過も扱える。モダン用途の標準",[63,885,886,889],{},[38,887,888],{},"AVIF",": 更に小さいが生成コストが高く、ブラウザ対応がまだ揃いきらない",[11,891,892,893,896],{},"ブログや EC で表示速度を気にするなら ",[38,894,895],{},"WebP 一択","と言って差し支えありません。",[28,898,388],{"id":388},[11,900,901,902,905],{},"Canvas API の ",[23,903,904],{},"canvas.toBlob(callback, 'image\u002Fwebp', quality)"," を使って変換しています。ブラウザ標準のエンコーダなので、外部ライブラリ依存もありません。",[87,907,908,915,922],{},[63,909,910,911,914],{},"入力画像を ",[23,912,913],{},"\u003Cimg>"," として読み込み",[63,916,917,918,921],{},"同寸の ",[23,919,920],{},"\u003Ccanvas>"," に描画",[63,923,924,927],{},[23,925,926],{},"toBlob"," で出力形式と品質を指定して書き出し",[11,929,930,931,934],{},"HEIC 入力のみ別ツール (",[18,932,933],{"href":677},"HEIC → JPG",") に振り分けています。これは HEIC デコーダがブラウザ標準にまだ入っていないため、別ライブラリを読み込む必要があるためです。",[28,936,190],{"id":190},[11,938,939,942],{},[38,940,941],{},"Q. 透過 PNG を JPEG にしたらどうなる？","\nA. 透過部分は白で塗られます。意図しない結果になりやすいので注意してください。",[11,944,945,948],{},[38,946,947],{},"Q. 元のメタデータ (EXIF) は引き継がれる？","\nA. 落ちます。位置情報漏れの予防としてはむしろ利点です。",[11,950,951,954],{},[38,952,953],{},"Q. バッチ処理の上限は？","\nA. 端末のメモリ次第ですが、実用上は 100 枚前後までを推奨します。",[28,956,217],{"id":217},[87,958,959,964,969],{},[63,960,961,963],{},[18,962,780],{"href":779}," — 品質指定で再エンコードしてサイズ削減",[63,965,966,968],{},[18,967,787],{"href":786}," — 形式変換と同時に寸法も揃えたいときは先にこちら",[63,970,971,973],{},[18,972,933],{"href":677}," — iPhone 写真専用の変換",{"title":245,"searchDepth":246,"depth":246,"links":975},[976,977,978,979,980,981],{"id":830,"depth":246,"text":830},{"id":55,"depth":246,"text":55},{"id":330,"depth":246,"text":330},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の画像形式変換ツールは、JPEG \u002F PNG \u002F WebP \u002F AVIF をサーバーに送らず相互変換します。用途別の形式選び、透過・圧縮率の違いを Zerosend 編集部が整理します。",{},"\u002Fblog\u002Fimage-convert-intro",{"title":816,"description":982},"image-convert-intro","blog\u002Fimage-convert-intro",[811,485,882,275],"MAlk3sjsYuu6xgnHtqBBQOwIM5KbQiMdHPIStC5QIcU",{"id":991,"title":992,"author":6,"body":993,"category":259,"coverImage":260,"description":1149,"draft":262,"extension":263,"locale":264,"meta":1150,"navigation":266,"noindex":262,"path":1151,"publishedAt":268,"seo":1152,"slug":1153,"stem":1154,"tags":1155,"updatedAt":268,"__hash__":1157},"blog\u002Fblog\u002Fimage-edit-intro.md","画像の切り抜き・回転・反転をブラウザ内で — \u002Ftools\u002Fimage-edit の思想と使い方",{"type":8,"value":994,"toc":1142},[995,998,1005,1008,1011,1018,1021,1023,1060,1062,1098,1101,1103,1109,1115,1121,1123],[11,996,997],{},"SNS アイコンの正方形切り出し、履歴書の証明写真の比率合わせ、商品画像の回転、スキャン画像の左右反転。画像の「切り抜き・回転・反転」は、Photoshop を開くほどでもないのに地味に面倒な作業です。",[11,999,1000,1004],{},[18,1001,1003],{"href":1002},"\u002Ftools\u002Fimage-edit","Zerosend の画像編集ツール"," は、この 3 操作を 1 画面に集約してブラウザ内で完結させます。",[28,1006,1007],{"id":1007},"なぜブラウザ内で編集するのか",[11,1009,1010],{},"トリミングは個人情報と密接です。証明写真を切り出すなら顔、名刺をスキャンするなら氏名・連絡先、社内資料の一部を切り出すなら機密情報が含まれます。",[11,1012,1013,1014,1017],{},"これらを「画像を切り抜くだけ」のオンラインツールにアップロードしてしまうと、切り抜き前の原版が相手のサーバーに残る可能性があります。オンラインツールはビジネスモデル上、アップロード済みのファイルをログ・解析・AI 学習に回しても契約上問題にならないケースが多く、",[38,1015,1016],{},"利用者側からはその境界が見えません","。",[11,1019,1020],{},"Zerosend は編集処理そのものをローカルで行うことで、この不透明性を取り除きます。",[28,1022,55],{"id":55},[60,1024,1025,1031,1034,1057],{},[63,1026,1027,69],{},[18,1028,1029],{"href":1002},[23,1030,1002],{},[63,1032,1033],{},"画像をドラッグ&ドロップ",[63,1035,1036,1037],{},"3 つの操作から選ぶ:\n",[87,1038,1039,1045,1051],{},[63,1040,1041,1044],{},[38,1042,1043],{},"切り抜き",": 矩形を選択範囲として指定",[63,1046,1047,1050],{},[38,1048,1049],{},"回転",": 90° \u002F 180° \u002F 270° の 3 ステップ",[63,1052,1053,1056],{},[38,1054,1055],{},"反転",": 水平 \u002F 垂直",[63,1058,1059],{},"プレビューで結果を確認してダウンロード",[28,1061,388],{"id":388},[87,1063,1064,1076,1085],{},[63,1065,1066,1068,1069,1071,1072,1075],{},[38,1067,1043],{},": 選択した矩形の寸法の ",[23,1070,920],{}," を作り、",[23,1073,1074],{},"drawImage"," で元画像の該当領域を切り出し",[63,1077,1078,1080,1081,1084],{},[38,1079,1049],{},": 回転行列を ",[23,1082,1083],{},"ctx.transform"," で適用してから描画",[63,1086,1087,1089,1090,1093,1094,1097],{},[38,1088,1055],{},": ",[23,1091,1092],{},"ctx.scale(-1, 1)"," で水平、",[23,1095,1096],{},"ctx.scale(1, -1)"," で垂直",[11,1099,1100],{},"いずれも Canvas API の基本操作の組み合わせで、追加ライブラリは使っていません。処理は数十ミリ秒で完了します。",[28,1102,190],{"id":190},[11,1104,1105,1108],{},[38,1106,1107],{},"Q. 比率指定 (1:1, 4:3, 16:9) で切り抜けますか？","\nA. はい。プリセットボタンで一発切り替えできます。SNS アイコンは 1:1、YouTube サムネは 16:9 など。",[11,1110,1111,1114],{},[38,1112,1113],{},"Q. 複数画像をまとめて同じ比率で切り抜けますか？","\nA. 現状は 1 枚ずつです。バッチ処理は要望を見ながら検討します。",[11,1116,1117,1120],{},[38,1118,1119],{},"Q. 編集後に再度編集したい場合は？","\nA. ダウンロードしたファイルを再度ドロップすれば、何度でも編集できます。",[28,1122,217],{"id":217},[87,1124,1125,1130,1135],{},[63,1126,1127,1129],{},[18,1128,787],{"href":786}," — 切り抜き後に寸法を揃えたいとき",[63,1131,1132,1134],{},[18,1133,780],{"href":779}," — 編集後の軽量化",[63,1136,1137,1141],{},[18,1138,1140],{"href":1139},"\u002Ftools\u002Fimage-merge","画像結合"," — 複数画像を 1 枚にまとめたいとき",{"title":245,"searchDepth":246,"depth":246,"links":1143},[1144,1145,1146,1147,1148],{"id":1007,"depth":246,"text":1007},{"id":55,"depth":246,"text":55},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の画像編集ツールは、切り抜き・回転・反転をサーバーに送らず端末内で処理します。証明写真・SNS アイコン・商品画像のトリミングで使える基本操作を Zerosend 編集部が解説。",{},"\u002Fblog\u002Fimage-edit-intro",{"title":992,"description":1149},"image-edit-intro","blog\u002Fimage-edit-intro",[811,1156,275],"編集","h6iWKKMINFrYbTea9JQU_0-L2ODwN_Y0BCWM2BAGAdE",{"id":1159,"title":1160,"author":6,"body":1161,"category":259,"coverImage":260,"description":1321,"draft":262,"extension":263,"locale":264,"meta":1322,"navigation":266,"noindex":262,"path":1323,"publishedAt":268,"seo":1324,"slug":1325,"stem":1326,"tags":1327,"updatedAt":268,"__hash__":1329},"blog\u002Fblog\u002Fimage-merge-intro.md","複数画像を 1 枚にまとめる — \u002Ftools\u002Fimage-merge の思想と使い方",{"type":8,"value":1162,"toc":1313},[1163,1166,1172,1175,1182,1185,1187,1210,1212,1238,1241,1243,1269,1271,1280,1286,1292,1294],[11,1164,1165],{},"スマホのスクリーンショットを複数枚まとめて 1 枚の縦長画像にしたい。商品のビフォーアフター画像を 1 枚で見せたい。SNS に 4 コマ風に並べて投稿したい。",[11,1167,1168,1171],{},[18,1169,1170],{"href":1139},"Zerosend の画像結合ツール"," は、こうした「複数画像を 1 枚にまとめる」需要をブラウザ内で完結させます。",[28,1173,1174],{"id":1174},"なぜブラウザ内で結合するのか",[11,1176,1177,1178,1181],{},"結合対象の画像には、アプリの画面キャプチャ、社内ドキュメントのスクショ、顧客の LINE 履歴など機密性の高いものが混ざりがちです。",[38,1179,1180],{},"結合対象を全部まとめてサーバーに上げる","ということは、それだけの量の機密情報を一度に外に出すことと同じです。",[11,1183,1184],{},"Zerosend は結合処理そのものがローカルで動くため、何枚投入しても 1 枚のファイルも外に出ません。",[28,1186,55],{"id":55},[60,1188,1189,1195,1198,1201,1204,1207],{},[63,1190,1191,69],{},[18,1192,1193],{"href":1139},[23,1194,1139],{},[63,1196,1197],{},"画像を複数枚ドラッグ&ドロップ",[63,1199,1200],{},"結合方向を選ぶ (縦に連結 \u002F 横に連結 \u002F グリッド)",[63,1202,1203],{},"順序が違う場合はドラッグで並べ替え",[63,1205,1206],{},"「結合を開始する」をクリック",[63,1208,1209],{},"1 枚の画像としてダウンロード",[28,1211,388],{"id":388},[87,1213,1214,1217,1223,1229,1232],{},[63,1215,1216],{},"各入力画像の寸法を計測",[63,1218,1219,1220,1222],{},"結合後の ",[23,1221,920],{}," サイズを計算 (縦連結なら幅は最大・高さは合計)",[63,1224,1225,1226,1228],{},"画像を順に ",[23,1227,1074],{}," で配置",[63,1230,1231],{},"幅\u002F高さが揃わない場合は縦横比を保って自動センタリング",[63,1233,1234,1237],{},[23,1235,1236],{},"canvas.toBlob()"," で PNG \u002F JPEG として書き出し",[11,1239,1240],{},"全処理は Canvas API の組み合わせで完結します。100 枚程度の結合までは現実的です。",[28,1242,570],{"id":570},[87,1244,1245,1251,1257,1263],{},[63,1246,1247,1250],{},[38,1248,1249],{},"スクショ集約",": アプリのフロー解説で、複数画面を 1 枚にまとめて Slack に貼る",[63,1252,1253,1256],{},[38,1254,1255],{},"比較画像",": ビフォー\u002Fアフターを横並びで 1 枚に",[63,1258,1259,1262],{},[38,1260,1261],{},"SNS 投稿",": Instagram の 1 枚投稿でも複数カットを見せる",[63,1264,1265,1268],{},[38,1266,1267],{},"申請書類",": 表紙と本文を 1 画像にまとめて提出",[28,1270,190],{"id":190},[11,1272,1273,1276,1277,1279],{},[38,1274,1275],{},"Q. 画像サイズが違うものを結合するとどうなる？","\nA. 縦連結では幅を最大に合わせ、余白部分は透明 (PNG) または白 (JPEG) になります。事前に ",[18,1278,787],{"href":786}," で揃えておくときれいに仕上がります。",[11,1281,1282,1285],{},[38,1283,1284],{},"Q. 間に余白を入れられる？","\nA. はい。境界の色と幅を指定できます。",[11,1287,1288,1291],{},[38,1289,1290],{},"Q. グリッドの行数・列数は指定できる？","\nA. はい。例えば 4 枚を 2×2 のグリッドに配置できます。",[28,1293,217],{"id":217},[87,1295,1296,1301,1306],{},[63,1297,1298,1300],{},[18,1299,787],{"href":786}," — 結合前にサイズを揃える",[63,1302,1303,1305],{},[18,1304,780],{"href":779}," — 結合後の巨大ファイルを軽くする",[63,1307,1308,1312],{},[18,1309,1311],{"href":1310},"\u002Ftools\u002Fimage-to-pdf","画像 → PDF"," — 結合の代わりに PDF 1 枚にまとめる選択肢も",{"title":245,"searchDepth":246,"depth":246,"links":1314},[1315,1316,1317,1318,1319,1320],{"id":1174,"depth":246,"text":1174},{"id":55,"depth":246,"text":55},{"id":388,"depth":246,"text":388},{"id":570,"depth":246,"text":570},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の画像結合ツールは、複数の画像をサーバーに送らずブラウザ内で縦\u002F横に連結します。比較画像・ビフォーアフター・スマホのスクリーンショット集約に。Zerosend 編集部が解説。",{},"\u002Fblog\u002Fimage-merge-intro",{"title":1160,"description":1321},"image-merge-intro","blog\u002Fimage-merge-intro",[811,1328,275],"結合","PLfuzw4Y8oCuQtuvMqC3PyVOdK3FVJAmKrbBGTfyyc8",{"id":1331,"title":1332,"author":6,"body":1333,"category":259,"coverImage":260,"description":1507,"draft":262,"extension":263,"locale":264,"meta":1508,"navigation":266,"noindex":262,"path":1509,"publishedAt":268,"seo":1510,"slug":1511,"stem":1512,"tags":1513,"updatedAt":268,"__hash__":1515},"blog\u002Fblog\u002Fimage-resize-intro.md","画像リサイズをブラウザ内で — \u002Ftools\u002Fimage-resize の思想と使い方",{"type":8,"value":1334,"toc":1498},[1335,1338,1344,1347,1353,1360,1362,1381,1384,1422,1424,1430,1455,1458,1460,1466,1472,1478,1480],[11,1336,1337],{},"SNS に投稿したい、社内 Wiki に貼りたい、ECサイトの商品画像に使いたい。用途ごとに必要な画像サイズは違います。スマホで撮った 4000×3000 ピクセルの写真をそのままアップすると、受け側サーバーで勝手に縮小されたり、表示が重くなったりします。",[11,1339,1340,1343],{},[18,1341,1342],{"href":786},"Zerosend の画像リサイズツール"," は、この「用途に合う寸法に先に揃えておきたい」需要をブラウザ内で完結させます。",[28,1345,1346],{"id":1346},"なぜブラウザ内でリサイズするのか",[11,1348,1349,1350,1017],{},"画像は、送信前に必要な解像度まで落としておくのが基本です。受け側サーバーの自動縮小に任せると、圧縮アルゴリズムを自分で選べず、結果も見えません。何より、",[38,1351,1352],{},"元の高解像度がサーバー側に残ります",[11,1354,1355,1356,1359],{},"顔写真、社員証、内装写真、診断書のスキャン。個人情報が含まれる画像を、ブラウザの「縮小してアップロード」機能付きサービスに投げることは、結果的に",[38,1357,1358],{},"原寸画像をそのままアップロードしている","のと同じです。Zerosend では、リサイズ処理そのものをあなたの端末で行うことで、アップロードする画像が本当に縮小済みであることを保証します。",[28,1361,55],{"id":55},[60,1363,1364,1370,1373,1376,1379],{},[63,1365,1366,69],{},[18,1367,1368],{"href":786},[23,1369,786],{},[63,1371,1372],{},"画像をドラッグ&ドロップ (複数ファイル対応)",[63,1374,1375],{},"目標サイズを指定 — 「幅」「高さ」「長辺」「短辺」のいずれかを固定",[63,1377,1378],{},"「リサイズを開始する」をクリック",[63,1380,861],{},[83,1382,1383],{"id":1383},"用途別の推奨サイズ",[87,1385,1386,1392,1398,1404,1410,1416],{},[63,1387,1388,1391],{},[38,1389,1390],{},"X \u002F Twitter",": 長辺 1600px",[63,1393,1394,1397],{},[38,1395,1396],{},"Instagram",": 正方形 1080px",[63,1399,1400,1403],{},[38,1401,1402],{},"LinkedIn \u002F Facebook",": 長辺 1200px",[63,1405,1406,1409],{},[38,1407,1408],{},"ブログ本文",": 幅 800〜1200px",[63,1411,1412,1415],{},[38,1413,1414],{},"メールの添付",": 長辺 1024px 程度 (画質維持しつつ 500KB 以下に収まりやすい)",[63,1417,1418,1421],{},[38,1419,1420],{},"ECサイトのサムネ",": 幅 400〜600px",[28,1423,388],{"id":388},[11,1425,1426,1427,1429],{},"画像リサイズは、Canvas API の ",[23,1428,1074],{}," を使ったブラウザ標準のバイキュービック補間で行っています。外部ライブラリの呼び出しも、サーバーへの問い合わせもありません。",[87,1431,1432,1438,1444,1450],{},[63,1433,1434,1435,1437],{},"画像を ",[23,1436,913],{}," 要素として読み込む",[63,1439,1440,1441,1443],{},"目標サイズの ",[23,1442,920],{}," を作成",[63,1445,1446,1449],{},[23,1447,1448],{},"ctx.drawImage(img, 0, 0, targetW, targetH)"," で描画",[63,1451,1452,1454],{},[23,1453,1236],{}," で出力形式 (JPEG \u002F PNG \u002F WebP) を指定して Blob に",[11,1456,1457],{},"一括処理は Promise.all ではなく順次実行しているため、数十枚でもメモリを圧迫しません。",[28,1459,190],{"id":190},[11,1461,1462,1465],{},[38,1463,1464],{},"Q. 縦横比は保持されますか？","\nA. 既定で保持されます。「幅を合わせる」を選べば高さは自動で計算されます。",[11,1467,1468,1471],{},[38,1469,1470],{},"Q. EXIF (撮影情報) は？","\nA. リサイズ時に落ちます。プライバシー保護の観点ではむしろ利点です。",[11,1473,1474,1477],{},[38,1475,1476],{},"Q. 拡大もできますか？","\nA. できますが推奨しません。拡大は情報を増やせないため、AI 超解像を使わない限り画質は改善しません。",[28,1479,217],{"id":217},[87,1481,1482,1487,1492],{},[63,1483,1484,1486],{},[18,1485,780],{"href":779}," — リサイズ後にさらに軽くしたいときに",[63,1488,1489,1491],{},[18,1490,794],{"href":793}," — WebP \u002F JPEG \u002F PNG の変換",[63,1493,1494,1497],{},[18,1495,1496],{"href":1002},"画像編集"," — 切り抜き・回転・反転",{"title":245,"searchDepth":246,"depth":246,"links":1499},[1500,1501,1504,1505,1506],{"id":1346,"depth":246,"text":1346},{"id":55,"depth":246,"text":55,"children":1502},[1503],{"id":1383,"depth":252,"text":1383},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の画像リサイズツールは、画像をサーバーに送らず端末内で寸法変更します。用途別の推奨サイズ、一括処理、品質を落とさないリサイズのコツを Zerosend 編集部が解説。",{},"\u002Fblog\u002Fimage-resize-intro",{"title":1332,"description":1507},"image-resize-intro","blog\u002Fimage-resize-intro",[811,1514,275],"リサイズ","cgPCku-ryY9cT1OjPSzWlJ8Aix9IFfaosaRwJBW9JMw",{"id":1517,"title":1518,"author":6,"body":1519,"category":259,"coverImage":260,"description":1674,"draft":262,"extension":263,"locale":264,"meta":1675,"navigation":266,"noindex":262,"path":1676,"publishedAt":268,"seo":1677,"slug":1678,"stem":1679,"tags":1680,"updatedAt":268,"__hash__":1682},"blog\u002Fblog\u002Fimage-to-pdf-intro.md","画像を 1 つの PDF にまとめる — \u002Ftools\u002Fimage-to-pdf の思想と使い方",{"type":8,"value":1520,"toc":1667},[1521,1524,1529,1531,1538,1545,1547,1570,1572,1578,1609,1612,1614,1620,1629,1635,1644,1646],[11,1522,1523],{},"スマホで撮ったレシート 10 枚を経費精算で PDF にまとめる、スキャンした書類 15 枚を 1 つの PDF にまとめて申請する、商品写真を PDF カタログにする。「画像 → PDF」の変換は、個人から業務まで頻繁に発生する作業です。",[11,1525,1526,292],{},[18,1527,1528],{"href":1310},"Zerosend の画像 → PDF 変換ツール",[28,1530,295],{"id":295},[11,1532,1533,1534,1537],{},"画像 → PDF 変換の入力は、写真・スキャン・スクリーンショットです。つまり",[38,1535,1536],{},"画像 1 枚ずつが個別の機密情報","を持ちます。レシートなら店名・金額・日時・クレカ下 4 桁、スキャン書類なら本文全体、スクショなら画面に写っているすべて。",[11,1539,1540,1541,1544],{},"それらをまとめてオンライン PDF 化サービスに投げるのは、",[38,1542,1543],{},"機密情報セットをまとめて外に出す","ことに他なりません。Zerosend ではローカルで PDF 組み立てまで行うため、アップロードは発生しません。",[28,1546,55],{"id":55},[60,1548,1549,1555,1558,1561,1564,1567],{},[63,1550,1551,69],{},[18,1552,1553],{"href":1310},[23,1554,1310],{},[63,1556,1557],{},"画像を複数枚ドラッグ&ドロップ (JPEG \u002F PNG \u002F WebP)",[63,1559,1560],{},"ページサイズ (A4 \u002F レター \u002F 画像原寸) と向きを選ぶ",[63,1562,1563],{},"並び順をドラッグで調整",[63,1565,1566],{},"「PDF 化を開始する」をクリック",[63,1568,1569],{},"1 つの PDF ファイルとしてダウンロード",[28,1571,388],{"id":388},[11,1573,1574,1577],{},[23,1575,1576],{},"pdf-lib"," を使って PDF を組み立てています。",[87,1579,1580,1583,1589,1600,1603],{},[63,1581,1582],{},"各画像を ArrayBuffer で読み込み",[63,1584,1585,1588],{},[23,1586,1587],{},"PDFDocument.create()"," で新規ドキュメントを作成",[63,1590,1591,1592,1595,1596,1599],{},"ページごとに ",[23,1593,1594],{},"pdfDoc.embedJpg()"," または ",[23,1597,1598],{},"embedPng()"," で画像を埋め込み",[63,1601,1602],{},"ページサイズに合わせて自動で縮小・センタリング",[63,1604,1605,1608],{},[23,1606,1607],{},".save()"," で最終的な PDF バイト列に",[11,1610,1611],{},"画像のサイズ指定は縦横比を保持したまま、指定ページサイズに収まるよう計算されます。",[28,1613,190],{"id":190},[11,1615,1616,1619],{},[38,1617,1618],{},"Q. 画像の順序は変えられますか？","\nA. はい。追加した順に並びますが、ドラッグで並べ替えできます。",[11,1621,1622,1625,1626,1628],{},[38,1623,1624],{},"Q. 画像の向き (縦\u002F横) を個別に変えられますか？","\nA. ページ単位の向きは全体で統一されます。個別に回転したい場合は ",[18,1627,1496],{"href":1002}," で先に回転してから PDF 化してください。",[11,1630,1631,1634],{},[38,1632,1633],{},"Q. OCR (文字認識) はかかる？","\nA. かかりません。画像はそのまま PDF に埋め込まれます。検索可能 PDF にしたい場合は別途 OCR ツールを通してください (プライバシー観点では、OCR もローカルで完結するツールを選ぶべきです)。",[11,1636,1637,1640,1641,1643],{},[38,1638,1639],{},"Q. 圧縮は？","\nA. 元画像がそのまま埋め込まれるため、PDF が大きくなりがちです。事前に ",[18,1642,780],{"href":779}," してから投入すると、最終 PDF が軽くなります。",[28,1645,217],{"id":217},[87,1647,1648,1653,1660],{},[63,1649,1650,1652],{},[18,1651,780],{"href":779}," — PDF 化前に画像を軽くする",[63,1654,1655,1659],{},[18,1656,1658],{"href":1657},"\u002Ftools\u002Fpdf-merge","PDF 結合"," — 既存 PDF と結合する",[63,1661,1662,1666],{},[18,1663,1665],{"href":1664},"\u002Ftools\u002Fpdf-to-image","PDF → 画像"," — 逆変換",{"title":245,"searchDepth":246,"depth":246,"links":1668},[1669,1670,1671,1672,1673],{"id":295,"depth":246,"text":295},{"id":55,"depth":246,"text":55},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の画像 → PDF 変換ツールは、複数画像をサーバーに送らず 1 つの PDF にまとめます。スキャン画像の PDF 化・レシートまとめ・申請書類の体裁整え。Zerosend 編集部が解説。",{},"\u002Fblog\u002Fimage-to-pdf-intro",{"title":1518,"description":1674},"image-to-pdf-intro","blog\u002Fimage-to-pdf-intro",[1681,811,485,275],"PDF","D6ubXIQ0K1VJPj8rh053Aq1XTT7bE9P36nsJMIHnsO4",{"id":1684,"title":1685,"author":6,"body":1686,"category":259,"coverImage":260,"description":1822,"draft":262,"extension":263,"locale":264,"meta":1823,"navigation":266,"noindex":262,"path":1824,"publishedAt":268,"seo":1825,"slug":1826,"stem":1827,"tags":1828,"updatedAt":268,"__hash__":1829},"blog\u002Fblog\u002Fpdf-compress-intro.md","PDF を圧縮する — \u002Ftools\u002Fpdf-compress の思想と使い方",{"type":8,"value":1687,"toc":1815},[1688,1691,1697,1700,1707,1710,1712,1731,1734,1738,1741,1761,1768,1770,1776,1782,1788,1794,1796],[11,1689,1690],{},"メールで PDF を送ろうとしたら「ファイルサイズが大きすぎます」と弾かれた、Slack の無料枠を食い潰す、見積書 PDF が 30MB あって顧客にストレスを与えている。PDF のサイズ圧縮は、業務の摩擦を減らすのに効く小さな改善です。",[11,1692,1693,292],{},[18,1694,1696],{"href":1695},"\u002Ftools\u002Fpdf-compress","Zerosend の PDF 圧縮ツール",[28,1698,1699],{"id":1699},"なぜブラウザ内で圧縮するのか",[11,1701,1702,1703,1706],{},"PDF 圧縮サービスの大半はアップロード型です。つまり",[38,1704,1705],{},"契約書・見積書・健康診断・給与明細を他社サーバーに預ける","ことになります。「削除します」と書かれていても、その履行をユーザーが確認する術はありません。",[11,1708,1709],{},"Zerosend は圧縮処理をローカルで行うため、機密性の高い PDF をそのまま投入できます。DevTools で本当にアップロードされていないことを確認してから、安心して使ってください。",[28,1711,55],{"id":55},[60,1713,1714,1720,1723,1726,1728],{},[63,1715,1716,69],{},[18,1717,1718],{"href":1695},[23,1719,1695],{},[63,1721,1722],{},"PDF をドラッグ&ドロップ",[63,1724,1725],{},"画質レベルを選択 (高品質 \u002F 標準 \u002F 低品質)",[63,1727,78],{},[63,1729,1730],{},"軽量化された PDF をダウンロード",[11,1732,1733],{},"スキャン由来の画像 PDF に特に効果があります。ベクタ主体のテキスト PDF はもともと軽いので削減率は控えめです。",[28,1735,1737],{"id":1736},"仕組み-ラスタライズによる再構築","仕組み — ラスタライズによる再構築",[11,1739,1740],{},"Zerosend の PDF 圧縮は、一度ページを画像化して再構築する方式です。",[87,1742,1743,1750,1753,1758],{},[63,1744,1745,1746,1749],{},"元 PDF を ",[23,1747,1748],{},"pdfjs-dist"," で各ページをキャンバスに描画",[63,1751,1752],{},"描画結果を指定品質で JPEG にエンコード",[63,1754,1755,1757],{},[23,1756,1576],{}," で新しい PDF を組み立て、JPEG ページを埋め込み",[63,1759,1760],{},"元 PDF の metadata (タイトル・作成者など) は引き継ぐ",[11,1762,1763,1764,1767],{},"このアプローチの強みはサイズ削減率の高さ、弱みは",[38,1765,1766],{},"ベクタ情報が失われること"," (テキスト選択・検索不可になる) です。テキスト検索性を維持したい場合は、元 PDF のまま送るか、軽量化の必要性を再検討してください。",[28,1769,190],{"id":190},[11,1771,1772,1775],{},[38,1773,1774],{},"Q. 削減率はどのくらい？","\nA. 画像主体のスキャン PDF なら 50〜80% 減ることもあります。テキスト主体の PDF は 10〜30% 程度です。",[11,1777,1778,1781],{},[38,1779,1780],{},"Q. 圧縮後にテキスト検索できなくなった","\nA. ラスタライズ方式の副作用です。「標準」設定では解像度を維持するため読みやすさは保ちますが、テキストとしては検索できません。",[11,1783,1784,1787],{},[38,1785,1786],{},"Q. OCR は含まれますか？","\nA. 現状は非対応です。圧縮後の PDF を検索可能にしたい場合は、別途 OCR ツールが必要です。",[11,1789,1790,1793],{},[38,1791,1792],{},"Q. 元の PDF が暗号化されている場合は？","\nA. パスワード保護された PDF は処理できません。先にロック解除が必要です。",[28,1795,217],{"id":217},[87,1797,1798,1803,1810],{},[63,1799,1800,1802],{},[18,1801,1658],{"href":1657}," — 圧縮前に結合しておく",[63,1804,1805,1809],{},[18,1806,1808],{"href":1807},"\u002Ftools\u002Fpdf-split","PDF 分割"," — 必要なページだけ抽出すれば圧縮も不要なことが多い",[63,1811,1812,1814],{},[18,1813,780],{"href":779}," — スキャン前の個別画像を軽くしておく選択肢",{"title":245,"searchDepth":246,"depth":246,"links":1816},[1817,1818,1819,1820,1821],{"id":1699,"depth":246,"text":1699},{"id":55,"depth":246,"text":55},{"id":1736,"depth":246,"text":1737},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の PDF 圧縮ツールは、PDF をサーバーに送らずブラウザ内でページをラスタライズして再構築し、サイズを削減します。メール添付上限に引っかかる PDF を軽くしたいときに。",{},"\u002Fblog\u002Fpdf-compress-intro",{"title":1685,"description":1822},"pdf-compress-intro","blog\u002Fpdf-compress-intro",[1681,274,275],"VKeX-7oi09OkXSKTYY4F_Mac1HcdP3v8fAz8Brsj664",{"id":1831,"title":1832,"author":6,"body":1833,"category":259,"coverImage":260,"description":1989,"draft":262,"extension":263,"locale":264,"meta":1990,"navigation":266,"noindex":262,"path":1991,"publishedAt":268,"seo":1992,"slug":1993,"stem":1994,"tags":1995,"updatedAt":268,"__hash__":1996},"blog\u002Fblog\u002Fpdf-edit-intro.md","PDF のページを並べ替え・削除・回転 — \u002Ftools\u002Fpdf-edit の思想と使い方",{"type":8,"value":1834,"toc":1982},[1835,1838,1845,1847,1853,1856,1858,1896,1898,1927,1936,1938,1944,1950,1956,1962,1964],[11,1836,1837],{},"スキャンしたら逆向きになっていた、最終ページが白紙だから削除したい、契約書の章を入れ替えたい。PDF 編集の 9 割は「ページの並べ替え・削除・回転」で済みます。",[11,1839,1840,1844],{},[18,1841,1843],{"href":1842},"\u002Ftools\u002Fpdf-edit","Zerosend の PDF ページ編集ツール"," は、この基本 3 操作をブラウザ内で完結させます。",[28,1846,1007],{"id":1007},[11,1848,1849,1850,1017],{},"PDF 編集の対象は、ほぼ例外なく機密文書です。業務委託契約、秘密保持契約、顧客カルテ、社内規程、給与明細。これらを「ページを入れ替えるだけ」のオンラインサービスに預けると、",[38,1851,1852],{},"元の全ページが相手のサーバーに渡ります",[11,1854,1855],{},"「処理後にすぐ削除」と書かれていても、保存の痕跡や解析ログをユーザーが検証する手段はありません。Zerosend ではページ編集もローカル処理のため、この透明性の問題を構造的に回避できます。",[28,1857,55],{"id":55},[60,1859,1860,1866,1868,1871,1893],{},[63,1861,1862,69],{},[18,1863,1864],{"href":1842},[23,1865,1842],{},[63,1867,1722],{},[63,1869,1870],{},"ページサムネイル一覧が表示される",[63,1872,1873,1874],{},"操作:\n",[87,1875,1876,1882,1888],{},[63,1877,1878,1881],{},[38,1879,1880],{},"並べ替え",": ドラッグでページを入れ替え",[63,1883,1884,1887],{},[38,1885,1886],{},"削除",": 不要なページのゴミ箱アイコンをクリック",[63,1889,1890,1892],{},[38,1891,1049],{},": 各ページの回転アイコンで 90° 単位回転",[63,1894,1895],{},"「編集を完了する」をクリックして新しい PDF を出力",[28,1897,388],{"id":388},[87,1899,1900,1906,1909,1915,1922],{},[63,1901,1902,1903,1905],{},"PDF を ",[23,1904,1748],{}," でレンダリングしてサムネイル一覧を表示",[63,1907,1908],{},"ページの並び・削除・回転情報を UI 上で管理",[63,1910,1911,1912,1914],{},"「完了」操作時に ",[23,1913,1576],{}," を呼び出し、元 PDF から必要なページを順にコピー",[63,1916,1917,1918,1921],{},"回転は ",[23,1919,1920],{},"page.setRotation()"," で書き込み",[63,1923,1924,1925],{},"最終 PDF として ",[23,1926,1607],{},[11,1928,1929,1930,1932,1933,1935],{},"サムネ描画 (",[23,1931,1748],{},") と PDF 組み立て (",[23,1934,1576],{},") の 2 ライブラリで役割分担しています。",[28,1937,190],{"id":190},[11,1939,1940,1943],{},[38,1941,1942],{},"Q. 編集履歴は残りますか？","\nA. 新しい PDF として書き出すため、元ファイルは変更されません。必要なら元ファイルを別途保存しておいてください。",[11,1945,1946,1949],{},[38,1947,1948],{},"Q. ページを複製 (同じページを 2 回入れる) できますか？","\nA. 現状は非対応です。需要があれば追加します。",[11,1951,1952,1955],{},[38,1953,1954],{},"Q. テキストを編集したい","\nA. 本ツールはページ単位の操作のみです。テキスト書き換えや署名追加などは別ツールが必要です。",[11,1957,1958,1961],{},[38,1959,1960],{},"Q. 回転の粒度は？","\nA. 90° 単位のみです。PDF の仕様上、自由角度回転は本来のページ情報を損ねる可能性があるため非対応です。",[28,1963,217],{"id":217},[87,1965,1966,1971,1976],{},[63,1967,1968,1970],{},[18,1969,1808],{"href":1807}," — 編集ではなく切り分けたいとき",[63,1972,1973,1975],{},[18,1974,1658],{"href":1657}," — 複数 PDF を結合",[63,1977,1978,1981],{},[18,1979,1980],{"href":1695},"PDF 圧縮"," — 編集後のサイズ削減",{"title":245,"searchDepth":246,"depth":246,"links":1983},[1984,1985,1986,1987,1988],{"id":1007,"depth":246,"text":1007},{"id":55,"depth":246,"text":55},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の PDF ページ編集ツールは、PDF のページ順序変更・削除・回転をサーバーに送らず端末内で行います。スキャン時の向きミス修正や不要ページ削除に。Zerosend 編集部が解説。",{},"\u002Fblog\u002Fpdf-edit-intro",{"title":1832,"description":1989},"pdf-edit-intro","blog\u002Fpdf-edit-intro",[1681,1156,275],"SfzMAQON3OOM4AYZfz3xZ5qB71ytztm9DyebNNSWdJU",{"id":1998,"title":1999,"author":6,"body":2000,"category":259,"coverImage":260,"description":2157,"draft":262,"extension":263,"locale":264,"meta":2158,"navigation":266,"noindex":262,"path":2159,"publishedAt":268,"seo":2160,"slug":2161,"stem":2162,"tags":2163,"updatedAt":268,"__hash__":2165},"blog\u002Fblog\u002Fpdf-split-intro.md","PDF を分割する — \u002Ftools\u002Fpdf-split の思想と使い方",{"type":8,"value":2001,"toc":2150},[2002,2005,2010,2014,2020,2023,2026,2028,2065,2067,2072,2100,2103,2105,2111,2117,2130,2132],[11,2003,2004],{},"契約書の 2〜5 ページだけ送ればいい、100 ページの資料から関係者ごとに必要なページを分けて配りたい、スキャン時に 1 つの PDF にしてしまった複数書類を切り分けたい。PDF の分割は業務で頻繁に発生します。",[11,2006,2007,292],{},[18,2008,2009],{"href":1807},"Zerosend の PDF 分割ツール",[28,2011,2013],{"id":2012},"なぜブラウザ内で-pdf-を分割するのか","なぜブラウザ内で PDF を分割するのか",[11,2015,2016,2017,1017],{},"PDF の中身は、契約書・見積書・健康診断結果・給与明細・設計資料など、ほぼすべてが機密性を持ちます。これを「PDF 分割できるオンラインサービス」にアップロードすると、",[38,2018,2019],{},"元の全ページが一旦そのサービスのサーバーに渡ります",[11,2021,2022],{},"ユーザー側が「2〜5 ページだけ必要」と思っていても、サービス側は全ページにアクセスできます。無料で提供されている以上、何らかの対価 (ログ・解析・AI 学習素材) としてファイルが使われている可能性は否定できません。",[11,2024,2025],{},"Zerosend は分割処理そのものがローカルで動くため、この構造的な問題を回避できます。",[28,2027,55],{"id":55},[60,2029,2030,2036,2039,2060,2063],{},[63,2031,2032,69],{},[18,2033,2034],{"href":1807},[23,2035,1807],{},[63,2037,2038],{},"PDF ファイルをドラッグ&ドロップ",[63,2040,2041,2042],{},"分割方法を選ぶ:\n",[87,2043,2044,2050],{},[63,2045,2046,2049],{},[38,2047,2048],{},"全ページを 1 ページずつ分割"," — 100 ページなら 100 ファイル",[63,2051,2052,2055,2056,2059],{},[38,2053,2054],{},"範囲指定"," — 例: ",[23,2057,2058],{},"1-3, 5, 7-10"," で複数範囲を抽出",[63,2061,2062],{},"「分割を開始する」をクリック",[63,2064,327],{},[28,2066,388],{"id":388},[11,2068,2069,2071],{},[23,2070,1576],{}," というブラウザで動く PDF 編集ライブラリを使っています。",[87,2073,2074,2077,2083,2089,2095],{},[63,2075,2076],{},"入力 PDF を ArrayBuffer として読み込み",[63,2078,2079,2082],{},[23,2080,2081],{},"PDFDocument.load()"," で解析",[63,2084,2085,2086,1443],{},"範囲指定に応じた新しい ",[23,2087,2088],{},"PDFDocument",[63,2090,2091,2094],{},[23,2092,2093],{},"copyPages()"," で必要なページだけコピー",[63,2096,2097,2099],{},[23,2098,1607],{}," で新しい PDF バイト列を生成",[11,2101,2102],{},"すべてメモリ上で処理し、ネットワークには一切送りません。",[28,2104,190],{"id":190},[11,2106,2107,2110],{},[38,2108,2109],{},"Q. 暗号化された PDF (パスワード保護) も分割できる？","\nA. パスワードなしの PDF のみ対応しています。暗号化 PDF は先にロック解除が必要です。",[11,2112,2113,2116],{},[38,2114,2115],{},"Q. ページ数が非常に多い PDF (500 ページなど) は？","\nA. 処理はできますが、ブラウザのメモリ次第で時間がかかります。数百 MB 規模の PDF は端末スペック次第で詰まる可能性があります。",[11,2118,2119,2122,2123,403,2126,2129],{},[38,2120,2121],{},"Q. 分割後のファイル名は？","\nA. 元ファイル名に ",[23,2124,2125],{},"-p1",[23,2127,2128],{},"-p2-5"," のようなサフィックスを付けます。",[28,2131,217],{"id":217},[87,2133,2134,2139,2145],{},[63,2135,2136,2138],{},[18,2137,1658],{"href":1657}," — 分割とは逆に、複数 PDF を 1 つに",[63,2140,2141,2144],{},[18,2142,2143],{"href":1842},"PDF ページ編集"," — ページの並べ替え・削除・回転",[63,2146,2147,2149],{},[18,2148,1980],{"href":1695}," — 分割後のファイルを軽くする",{"title":245,"searchDepth":246,"depth":246,"links":2151},[2152,2153,2154,2155,2156],{"id":2012,"depth":246,"text":2013},{"id":55,"depth":246,"text":55},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の PDF 分割ツールは、PDF をサーバーに送らずブラウザ内でページ単位\u002F範囲指定で分割します。機密文書の特定ページだけ共有したいときに。Zerosend 編集部が解説。",{},"\u002Fblog\u002Fpdf-split-intro",{"title":1999,"description":2157},"pdf-split-intro","blog\u002Fpdf-split-intro",[1681,2164,275],"分割","kCwJnR50yT43l5AF860iF-mBucf9FJ5nyTBuUsXsMyY",{"id":2167,"title":2168,"author":6,"body":2169,"category":259,"coverImage":260,"description":2332,"draft":262,"extension":263,"locale":264,"meta":2333,"navigation":266,"noindex":262,"path":2334,"publishedAt":268,"seo":2335,"slug":2336,"stem":2337,"tags":2338,"updatedAt":268,"__hash__":2339},"blog\u002Fblog\u002Fpdf-to-image-intro.md","PDF を画像に変換する — \u002Ftools\u002Fpdf-to-image の思想と使い方",{"type":8,"value":2170,"toc":2323},[2171,2174,2179,2181,2188,2191,2193,2211,2214,2234,2236,2241,2269,2272,2274,2283,2289,2295,2304,2306],[11,2172,2173],{},"プレゼン資料の 1 ページだけスクリーンショット的に使いたい、PDF の一部を SNS 投稿したい、PDF を見れない環境向けに画像で送りたい。「PDF → 画像」の変換は地味に需要があります。",[11,2175,2176,292],{},[18,2177,2178],{"href":1664},"Zerosend の PDF → 画像変換ツール",[28,2180,295],{"id":295},[11,2182,2183,2184,2187],{},"PDF から画像を切り出したい場面は、社内資料・顧客提案書・設計図・契約書スナップショットなど、機密度が高いケースが多いものです。「PDF の特定ページを画像にしたいだけ」と思ってオンラインツールに上げるときも、",[38,2185,2186],{},"アップロードされるのは PDF の全ページ","です。",[11,2189,2190],{},"Zerosend は変換処理をローカルで行うため、そもそも PDF が外に出ません。",[28,2192,55],{"id":55},[60,2194,2195,2201,2203,2206,2208],{},[63,2196,2197,69],{},[18,2198,2199],{"href":1664},[23,2200,1664],{},[63,2202,1722],{},[63,2204,2205],{},"出力形式 (PNG \u002F JPEG) と解像度を選ぶ",[63,2207,324],{},[63,2209,2210],{},"全ページの画像が ZIP で生成される",[83,2212,2213],{"id":2213},"解像度の目安",[87,2215,2216,2222,2228],{},[63,2217,2218,2221],{},[38,2219,2220],{},"72 DPI",": ウェブ掲載・SNS 投稿用。画質より軽さ優先",[63,2223,2224,2227],{},[38,2225,2226],{},"150 DPI",": 画面で読む標準品質",[63,2229,2230,2233],{},[38,2231,2232],{},"300 DPI",": 印刷品質。資料の細部が重要なとき",[28,2235,388],{"id":388},[11,2237,2238,2240],{},[23,2239,1748],{}," を使って各ページを Canvas に描画し、Canvas から画像として書き出しています。",[87,2242,2243,2246,2251,2261,2266],{},[63,2244,2245],{},"PDF を ArrayBuffer として読み込み",[63,2247,2248,2082],{},[23,2249,2250],{},"getDocument()",[63,2252,1591,2253,2256,2257,2260],{},[23,2254,2255],{},"getPage(n)"," → ",[23,2258,2259],{},"render(ctx, viewport)"," で Canvas に描画",[63,2262,2263,2265],{},[23,2264,1236],{}," で PNG \u002F JPEG 化",[63,2267,2268],{},"全ページを ZIP にまとめてダウンロード",[11,2270,2271],{},"ブラウザの描画エンジンをそのまま使うため、フォント埋め込み・ベクタ図・透過要素も正確に再現されます。",[28,2273,190],{"id":190},[11,2275,2276,2279,2280,2282],{},[38,2277,2278],{},"Q. 特定のページだけ変換できますか？","\nA. 現状は全ページが対象です。特定ページだけなら ",[18,2281,1808],{"href":1807}," で該当ページだけ抽出してから変換するのが確実です。",[11,2284,2285,2288],{},[38,2286,2287],{},"Q. 透過背景の PDF を変換するとどうなる？","\nA. PNG を選べば透過が保持されます。JPEG は透過非対応のため白背景になります。",[11,2290,2291,2294],{},[38,2292,2293],{},"Q. 画像の品質をもっと上げたい","\nA. 解像度を 300 DPI にすると大きく改善します。ただしファイルサイズとメモリ消費も大きくなります。",[11,2296,2297,2300,2301,2303],{},[38,2298,2299],{},"Q. 全ページを 1 枚にまとめたい","\nA. 本ツールは 1 ページ 1 ファイルです。まとめたい場合はダウンロード後 ",[18,2302,1140],{"href":1139}," で結合してください。",[28,2305,217],{"id":217},[87,2307,2308,2313,2318],{},[63,2309,2310,2312],{},[18,2311,1808],{"href":1807}," — ページ単位の抽出",[63,2314,2315,2317],{},[18,2316,780],{"href":779}," — 変換後の画像を軽くする",[63,2319,2320,2322],{},[18,2321,1140],{"href":1139}," — 変換した画像を 1 枚にまとめる",{"title":245,"searchDepth":246,"depth":246,"links":2324},[2325,2326,2329,2330,2331],{"id":295,"depth":246,"text":295},{"id":55,"depth":246,"text":55,"children":2327},[2328],{"id":2213,"depth":252,"text":2213},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の PDF → 画像変換ツールは、PDF の各ページをサーバーに送らずブラウザ内で PNG \u002F JPEG に書き出します。資料の一部だけ共有したいときに便利。Zerosend 編集部が解説。",{},"\u002Fblog\u002Fpdf-to-image-intro",{"title":2168,"description":2332},"pdf-to-image-intro","blog\u002Fpdf-to-image-intro",[1681,811,485,275],"Jq_DAUEoYgotOWAA8KjTcYylG7P9YgTbzLMPbniCMdc",{"id":2341,"title":2342,"author":6,"body":2343,"category":259,"coverImage":260,"description":2496,"draft":262,"extension":263,"locale":264,"meta":2497,"navigation":266,"noindex":262,"path":2498,"publishedAt":268,"seo":2499,"slug":2500,"stem":2501,"tags":2502,"updatedAt":268,"__hash__":2504},"blog\u002Fblog\u002Fqr-create-intro.md","QR コードを生成する — \u002Ftools\u002Fqr-create の思想と使い方",{"type":8,"value":2344,"toc":2488},[2345,2348,2355,2359,2365,2368,2371,2373,2393,2396,2422,2424,2430,2441,2444,2446,2452,2461,2467,2469],[11,2346,2347],{},"自社サイトの URL を名刺に載せる、Wi-Fi パスワードを会議室の壁に貼る、イベントのアンケート URL をポスターに印刷する。QR コードは、URL や短いテキストを物理空間に橋渡しする便利な手段です。",[11,2349,2350,2354],{},[18,2351,2353],{"href":2352},"\u002Ftools\u002Fqr-create","Zerosend の QR コード生成ツール"," は、QR を作る作業をブラウザ内で完結させます。",[28,2356,2358],{"id":2357},"なぜブラウザ内で-qr-を作るのか","なぜブラウザ内で QR を作るのか",[11,2360,2361,2362,1017],{},"QR 生成サービスの多くは、入力した URL やテキストをサーバーに送って画像を返す形式です。「URL を QR にしただけ」と思いがちですが、",[38,2363,2364],{},"どの URL を誰がいつ QR にしたかという履歴がサーバーに残り得ます",[11,2366,2367],{},"特に社内専用 URL、β版テスト URL、限定公開のアンケート URL などは、外部に知られたくない情報です。また、Wi-Fi パスワードや連絡先情報をテキストから QR 化する場合、中身がそのまま第三者のサーバーに渡ります。",[11,2369,2370],{},"Zerosend では QR 生成処理そのものがブラウザ内で完結するため、入力したテキストは一切外に出ません。",[28,2372,55],{"id":55},[60,2374,2375,2381,2384,2387,2390],{},[63,2376,2377,69],{},[18,2378,2379],{"href":2352},[23,2380,2352],{},[63,2382,2383],{},"テキスト・URL を入力",[63,2385,2386],{},"出力形式 (PNG \u002F SVG)・サイズ・誤り訂正レベルを選択",[63,2388,2389],{},"「QR を生成する」をクリック",[63,2391,2392],{},"画像をダウンロード",[28,2394,2395],{"id":2395},"誤り訂正レベルの選び方",[87,2397,2398,2404,2410,2416],{},[63,2399,2400,2403],{},[38,2401,2402],{},"L (Low, 7%)",": 小さい QR にしたいとき。印刷品質が良いなら実用十分",[63,2405,2406,2409],{},[38,2407,2408],{},"M (Medium, 15%)",": 汎用・標準",[63,2411,2412,2415],{},[38,2413,2414],{},"Q (Quartile, 25%)",": 名刺・ステッカーなど汚れ・折れが予想される用途",[63,2417,2418,2421],{},[38,2419,2420],{},"H (High, 30%)",": ロゴ重ね合わせ・屋外掲示で摩耗想定",[28,2423,388],{"id":388},[11,2425,2426,2429],{},[23,2427,2428],{},"qrcode"," という広く使われているブラウザ対応ライブラリを使っています。",[87,2431,2432,2435,2438],{},[63,2433,2434],{},"入力テキストから QR マトリクスを計算",[63,2436,2437],{},"Canvas に描画 (PNG) または SVG として直接生成",[63,2439,2440],{},"モジュール数・誤り訂正レベル・色指定に応じて調整",[11,2442,2443],{},"SVG で生成すれば、拡大縮小しても劣化しないベクタ画像が得られます。印刷用途には SVG がお勧めです。",[28,2445,190],{"id":190},[11,2447,2448,2451],{},[38,2449,2450],{},"Q. QR に含められるテキスト量は？","\nA. 仕様上は最大 4296 文字 (英数字)、日本語なら 1817 文字程度まで。長くなるほど QR の密度が上がり、スキャン成功率は下がります。URL 短縮サービスの利用も検討してください (ただしサードパーティ依存が増える)。",[11,2453,2454,2457,2458,2460],{},[38,2455,2456],{},"Q. ロゴを中央に重ねたい","\nA. 本ツールでは直接対応していませんが、PNG \u002F SVG をダウンロードしたあと ",[18,2459,1496],{"href":1002}," で合成できます。誤り訂正は H にしておくとスキャン成功率が上がります。",[11,2462,2463,2466],{},[38,2464,2465],{},"Q. 作った QR の履歴は残りますか？","\nA. 残りません。タブを閉じた時点ですべて消えます。",[28,2468,217],{"id":217},[87,2470,2471,2478,2483],{},[63,2472,2473,2477],{},[18,2474,2476],{"href":2475},"\u002Ftools\u002Fqr-read","QR コード読み取り"," — 生成した QR の検証・他人の QR の中身確認",[63,2479,2480,2482],{},[18,2481,1496],{"href":1002}," — QR にロゴを重ねる合成に",[63,2484,2485,2487],{},[18,2486,1311],{"href":1310}," — 複数 QR を 1 枚にまとめて印刷",{"title":245,"searchDepth":246,"depth":246,"links":2489},[2490,2491,2492,2493,2494,2495],{"id":2357,"depth":246,"text":2358},{"id":55,"depth":246,"text":55},{"id":2395,"depth":246,"text":2395},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の QR コード生成ツールは、URL やテキストをサーバーに送らずブラウザ内で QR 画像 (PNG \u002F SVG) に変換します。名刺・ポスター・プレゼン用の QR 作成に。Zerosend 編集部が解説。",{},"\u002Fblog\u002Fqr-create-intro",{"title":2342,"description":2496},"qr-create-intro","blog\u002Fqr-create-intro",[2503,275],"QR","DsH_yfTI7xypljWMDgLacgDgEhya0OFaN1gCRUol0hc",{"id":2506,"title":2507,"author":6,"body":2508,"category":259,"coverImage":260,"description":2680,"draft":262,"extension":263,"locale":264,"meta":2681,"navigation":266,"noindex":262,"path":2682,"publishedAt":268,"seo":2683,"slug":2684,"stem":2685,"tags":2686,"updatedAt":268,"__hash__":2688},"blog\u002Fblog\u002Fqr-read-intro.md","QR コードを読み取る — \u002Ftools\u002Fqr-read の思想と使い方",{"type":8,"value":2509,"toc":2672},[2510,2513,2519,2523,2530,2533,2547,2550,2552,2573,2575,2581,2599,2602,2605,2608,2626,2629,2631,2637,2646,2652,2654],[11,2511,2512],{},"怪しい広告に貼られていた QR、送られてきたチラシの QR、カメラで読むにはスマホを近づける距離が取りづらい QR。「画像として手元にある QR を PC でササッと中身だけ確認したい」という場面は意外と多いものです。",[11,2514,2515,2518],{},[18,2516,2517],{"href":2475},"Zerosend の QR 読み取りツール"," は、この用途のためにあります。フィッシングやスキャン型詐欺への自衛にも使えます。",[28,2520,2522],{"id":2521},"なぜブラウザ内で-qr-を読み取るのか","なぜブラウザ内で QR を読み取るのか",[11,2524,2525,2526,2529],{},"QR 読み取り=「カメラで撮って自動でリンクを開く」と考えがちですが、これは",[38,2527,2528],{},"危険な挙動","です。悪意のある QR はフィッシングサイト、マルウェア配布 URL、課金トラップ、不審なアプリインストールに誘導することがあります。",[11,2531,2532],{},"Zerosend はこれに対し 2 つの方針を取ります。",[60,2534,2535,2541],{},[63,2536,2537,2540],{},[38,2538,2539],{},"画像読み取り処理をローカルで行う"," — QR 画像を第三者に渡さない",[63,2542,2543,2546],{},[38,2544,2545],{},"デコード結果を自動遷移しない"," — URL が含まれていても、まずテキストとして表示し、ユーザーが内容を確認してから手動で判断できる",[11,2548,2549],{},"これはセキュリティ設計として重要な原則で、ZerosendのCLAUDE.mdにも「外部 URL への自動遷移禁止」として明記されています。",[28,2551,55],{"id":55},[60,2553,2554,2560,2563,2570],{},[63,2555,2556,69],{},[18,2557,2558],{"href":2475},[23,2559,2475],{},[63,2561,2562],{},"QR が写っている画像をドラッグ&ドロップ",[63,2564,2565,2566,2569],{},"自動でデコードが走り、結果が",[38,2567,2568],{},"プレーンテキスト","として表示される",[63,2571,2572],{},"内容を確認し、必要なら手動でコピー・遷移",[28,2574,388],{"id":388},[11,2576,2577,2580],{},[23,2578,2579],{},"jsQR"," というブラウザ対応の純 JavaScript QR デコーダを使っています。",[87,2582,2583,2587,2593,2596],{},[63,2584,1434,2585,921],{},[23,2586,920],{},[63,2588,2589,2592],{},[23,2590,2591],{},"getImageData()"," でピクセル配列を取得",[63,2594,2595],{},"jsQR がピクセル配列から QR を検出・デコード",[63,2597,2598],{},"結果をテキストとしてそのまま表示 (HTML として解釈しない・リンク化しない)",[11,2600,2601],{},"ライブラリは WASM ではなく純 JavaScript 実装のため、初回ロードが軽いのも特徴です。",[28,2603,2604],{"id":2604},"フィッシング対策としての使い方",[11,2606,2607],{},"怪しいメール・チラシ・SMS に QR が含まれているとき:",[60,2609,2610,2613,2620,2623],{},[63,2611,2612],{},"画像をスクリーンショットや保存で取得 (スキャンしない)",[63,2614,2615,2616,2619],{},"Zerosend で読み取って",[38,2617,2618],{},"テキストとして"," URL を確認",[63,2621,2622],{},"URL 構造に違和感がないかチェック (正規サイトのサブドメイン偽装、短縮 URL 経由、意味不明なパスなど)",[63,2624,2625],{},"問題なさそうなら手動でアドレスバーに入力して遷移",[11,2627,2628],{},"カメラで直接読むと一発でブラウザが開くリスクがありますが、この手順ならテキストで一度確認できます。",[28,2630,190],{"id":190},[11,2632,2633,2636],{},[38,2634,2635],{},"Q. 画像内に複数の QR がある場合は？","\nA. 現状は最初に検出された 1 つだけ読み取ります。",[11,2638,2639,2642,2643,2645],{},[38,2640,2641],{},"Q. 読み取れない QR","\nA. 解像度不足・反射・歪みが主な原因です。撮り直すか ",[18,2644,1496],{"href":1002}," で補正を試してください。",[11,2647,2648,2651],{},[38,2649,2650],{},"Q. 読み取り結果がサーバーに送られていないか確認したい","\nA. DevTools の Network タブを開いてから QR 画像をドロップしてください。通信が発生しないことが確認できます。",[28,2653,217],{"id":217},[87,2655,2656,2662,2667],{},[63,2657,2658,2661],{},[18,2659,2660],{"href":2352},"QR コード生成"," — 作った QR の検証にも使える",[63,2663,2664,2666],{},[18,2665,1496],{"href":1002}," — QR 画像の切り抜き・回転で読み取り成功率向上",[63,2668,2669,2671],{},[18,2670,780],{"href":779}," — 読み取れた QR 画像を軽く保存",{"title":245,"searchDepth":246,"depth":246,"links":2673},[2674,2675,2676,2677,2678,2679],{"id":2521,"depth":246,"text":2522},{"id":55,"depth":246,"text":55},{"id":388,"depth":246,"text":388},{"id":2604,"depth":246,"text":2604},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の QR 読み取りツールは、画像をサーバーに送らずブラウザ内で QR の中身をテキスト抽出します。リンク先の自動遷移はせず、安全に内容を確認できます。Zerosend 編集部が解説。",{},"\u002Fblog\u002Fqr-read-intro",{"title":2507,"description":2680},"qr-read-intro","blog\u002Fqr-read-intro",[2503,275,2687],"セキュリティ","4FjBNHwI0afA6UgHyTZbgfJtqb9hmC9rK5CiPA_rCgY",{"id":4,"title":5,"author":6,"body":2690,"category":259,"coverImage":260,"description":261,"draft":262,"extension":263,"locale":264,"meta":2848,"navigation":266,"noindex":262,"path":267,"publishedAt":268,"seo":2849,"slug":270,"stem":271,"tags":2850,"updatedAt":268,"__hash__":276},{"type":8,"value":2691,"toc":2836},[2692,2694,2700,2702,2704,2708,2714,2716,2718,2734,2736,2754,2756,2758,2760,2762,2768,2792,2794,2796,2800,2802,2806,2810,2814,2818,2820,2834],[11,2693,13],{},[11,2695,16,2696,26],{},[18,2697,21,2698,25],{"href":20},[23,2699,20],{},[28,2701,30],{"id":30},[11,2703,33],{},[11,2705,36,2706,41],{},[38,2707,40],{},[11,2709,44,2710,48,2712,52],{},[38,2711,47],{},[38,2713,51],{},[28,2715,55],{"id":55},[11,2717,58],{},[60,2719,2720,2726,2728,2730,2732],{},[63,2721,2722,69],{},[18,2723,2724],{"href":20},[23,2725,20],{},[63,2727,72],{},[63,2729,75],{},[63,2731,78],{},[63,2733,81],{},[83,2735,85],{"id":85},[87,2737,2738,2742,2746,2750],{},[63,2739,2740,94],{},[38,2741,93],{},[63,2743,2744,100],{},[38,2745,99],{},[63,2747,2748,106],{},[38,2749,105],{},[63,2751,2752,112],{},[38,2753,111],{},[11,2755,115],{},[28,2757,119],{"id":118},[11,2759,122],{},[83,2761,126],{"id":125},[11,2763,129,2764,133,2766,137],{},[23,2765,132],{},[38,2767,136],{},[87,2769,2770,2774,2778,2782,2786,2788],{},[63,2771,2772,145],{},[23,2773,144],{},[63,2775,2776,151],{},[23,2777,150],{},[63,2779,154,2780,158],{},[23,2781,157],{},[63,2783,2784,164],{},[23,2785,163],{},[63,2787,167],{},[63,2789,2790,173],{},[23,2791,172],{},[11,2793,176],{},[83,2795,180],{"id":179},[11,2797,183,2798,187],{},[23,2799,186],{},[28,2801,190],{"id":190},[11,2803,2804,196],{},[38,2805,195],{},[11,2807,2808,202],{},[38,2809,201],{},[11,2811,2812,208],{},[38,2813,207],{},[11,2815,2816,214],{},[38,2817,213],{},[28,2819,217],{"id":217},[87,2821,2822,2826,2830],{},[63,2823,2824,226],{},[18,2825,225],{"href":224},[63,2827,2828,233],{},[18,2829,232],{"href":231},[63,2831,2832,240],{},[18,2833,239],{"href":238},[11,2835,243],{},{"title":245,"searchDepth":246,"depth":246,"links":2837},[2838,2839,2842,2846,2847],{"id":30,"depth":246,"text":30},{"id":55,"depth":246,"text":55,"children":2840},[2841],{"id":85,"depth":252,"text":85},{"id":118,"depth":246,"text":119,"children":2843},[2844,2845],{"id":125,"depth":252,"text":126},{"id":179,"depth":252,"text":180},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},{},{"title":5,"description":261},[273,274,132,275],{"id":2852,"title":2853,"author":6,"body":2854,"category":259,"coverImage":260,"description":3007,"draft":262,"extension":263,"locale":264,"meta":3008,"navigation":266,"noindex":262,"path":3009,"publishedAt":268,"seo":3010,"slug":3011,"stem":3012,"tags":3013,"updatedAt":268,"__hash__":3014},"blog\u002Fblog\u002Fvideo-convert-intro.md","動画形式を変換する — \u002Ftools\u002Fvideo-convert の思想と使い方",{"type":8,"value":2855,"toc":2999},[2856,2859,2865,2867,2874,2877,2879,2898,2901,2921,2923,2926,2947,2950,2952,2958,2964,2973,2979,2981],[11,2857,2858],{},"iPhone で撮った MOV を Windows に送りたい、古いビデオカメラの AVI を YouTube に上げたい、ブラウザで再生できる形式に揃えたい。動画の形式変換は、互換性問題を解決する定番作業です。",[11,2860,2861,2864],{},[18,2862,2863],{"href":238},"Zerosend の動画形式変換ツール"," は、この変換をブラウザ内で完結させます。",[28,2866,295],{"id":295},[11,2868,2869,2870,2873],{},"動画ファイルは、それがどのような内容であっても",[38,2871,2872],{},"撮影者・被写体・撮影場所","という 3 種の個人情報を常に含みます。結婚式の映像、社内イベントの録画、研修動画、顧客インタビュー。これらを無料のオンライン変換サービスに預けることは、これらの映像を第三者のサーバーに一時的に置くことと同じです。",[11,2875,2876],{},"Zerosend では変換処理がローカルで完結するため、この構造的リスクを回避できます。",[28,2878,55],{"id":55},[60,2880,2881,2887,2890,2893,2895],{},[63,2882,2883,69],{},[18,2884,2885],{"href":238},[23,2886,238],{},[63,2888,2889],{},"動画ファイルをドラッグ&ドロップ",[63,2891,2892],{},"出力形式 (MP4 \u002F WebM) を選ぶ",[63,2894,324],{},[63,2896,2897],{},"ダウンロード",[28,2899,2900],{"id":2900},"形式の使い分け",[87,2902,2903,2909,2915],{},[63,2904,2905,2908],{},[38,2906,2907],{},"MP4 (H.264 + AAC)",": 汎用。ブラウザ・デバイス・SNS すべてで最も広く対応",[63,2910,2911,2914],{},[38,2912,2913],{},"WebM (VP9 + Opus)",": ブラウザネイティブ。ウェブサイト掲載で効率が良い",[63,2916,2917,2920],{},[38,2918,2919],{},"互換性優先なら MP4",": 現状、疑問があれば MP4 を選ぶのが安全",[28,2922,388],{"id":388},[11,2924,2925],{},"ffmpeg.wasm の再エンコードを利用しています。",[87,2927,2928,2931,2941,2944],{},[63,2929,2930],{},"入力動画を ffmpeg FS に書き込み",[63,2932,2933,2936,2937,2940],{},[23,2934,2935],{},"-c:v libx264 -c:a aac"," (MP4) または ",[23,2938,2939],{},"-c:v libvpx-vp9 -c:a libopus"," (WebM) で再エンコード",[63,2942,2943],{},"出力を Blob としてメモリに展開",[63,2945,2946],{},"ダウンロード用 URL を生成",[11,2948,2949],{},"再エンコードのため処理時間は入力の長さに比例します。30 秒の動画で数秒〜数十秒が目安です。",[28,2951,190],{"id":190},[11,2953,2954,2957],{},[38,2955,2956],{},"Q. 変換すると画質は落ちますか？","\nA. 再エンコードするため、理論上は多少劣化します。ただし実用レベルでは視覚的にほぼわからない範囲です。",[11,2959,2960,2963],{},[38,2961,2962],{},"Q. コーデック指定や高度なオプションを変えたい","\nA. 本ツールは一般用途向けのプリセットで固定しています。細かい制御が必要なら、別のプロフェッショナル向けツールを検討してください。",[11,2965,2966,2969,2970,2972],{},[38,2967,2968],{},"Q. 音声のみ抽出したい","\nA. ",[18,2971,566],{"href":290}," をお使いください。",[11,2974,2975,2978],{},[38,2976,2977],{},"Q. 対応していない入力形式","\nA. ffmpeg がサポートする範囲ですが、特殊コーデック (Pro Res \u002F DNxHD など) は未対応の場合があります。",[28,2980,217],{"id":217},[87,2982,2983,2989,2994],{},[63,2984,2985,2988],{},[18,2986,2987],{"href":20},"動画圧縮"," — 変換と同時にサイズも削減したいとき",[63,2990,2991,2993],{},[18,2992,232],{"href":231}," — 変換前に必要な区間だけ切り出す",[63,2995,2996,2998],{},[18,2997,566],{"href":290}," — 動画から音声だけ抽出して変換",{"title":245,"searchDepth":246,"depth":246,"links":3000},[3001,3002,3003,3004,3005,3006],{"id":295,"depth":246,"text":295},{"id":55,"depth":246,"text":55},{"id":2900,"depth":246,"text":2900},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の動画形式変換ツールは、MOV \u002F WebM \u002F MKV \u002F AVI などの動画をサーバーに送らずブラウザ内で MP4 など互換性の高い形式に変換します。Zerosend 編集部が解説。",{},"\u002Fblog\u002Fvideo-convert-intro",{"title":2853,"description":3007},"video-convert-intro","blog\u002Fvideo-convert-intro",[273,485,275],"i_qF2RQ1ekN3VuWdXHCBHMT8WsRj_g6jblGEPzBfnMo",{"id":3016,"title":3017,"author":6,"body":3018,"category":259,"coverImage":260,"description":3182,"draft":262,"extension":263,"locale":264,"meta":3183,"navigation":266,"noindex":262,"path":3184,"publishedAt":268,"seo":3185,"slug":3186,"stem":3187,"tags":3188,"updatedAt":268,"__hash__":3190},"blog\u002Fblog\u002Fvideo-to-gif-intro.md","動画を GIF に変換する — \u002Ftools\u002Fvideo-to-gif の思想と使い方",{"type":8,"value":3019,"toc":3174},[3020,3023,3028,3032,3038,3041,3043,3065,3068,3071,3097,3099,3110,3129,3132,3134,3143,3149,3155,3157],[11,3021,3022],{},"画面操作の説明を Slack で共有したい、バグの再現手順を issue に貼りたい、X のタイムラインで動く画像にしたい。動画が重くて共有しづらい場面で GIF は今でも現役です。",[11,3024,3025,2864],{},[18,3026,3027],{"href":224},"Zerosend の 動画 → GIF 変換ツール",[28,3029,3031],{"id":3030},"なぜブラウザ内で-gif-変換するのか","なぜブラウザ内で GIF 変換するのか",[11,3033,3034,3035,1017],{},"画面録画の中身は、UI スクリーンショット以上に情報を含みます。操作中に映る URL・ユーザー名・通知内容・顧客の名前。これらを含む動画を GIF 変換サービスにアップロードすると、",[38,3036,3037],{},"動画の全フレームが相手のサーバーに渡ります",[11,3039,3040],{},"Zerosend では変換処理をローカルで行うため、そのリスクがありません。DevTools で通信が発生していないことを確認してから使ってください。",[28,3042,55],{"id":55},[60,3044,3045,3051,3054,3057,3060,3063],{},[63,3046,3047,69],{},[18,3048,3049],{"href":224},[23,3050,224],{},[63,3052,3053],{},"動画ファイルをドラッグ&ドロップ (MP4 \u002F WebM \u002F MOV)",[63,3055,3056],{},"切り出し区間 (開始時刻・終了時刻) を指定",[63,3058,3059],{},"フレームレート (5 \u002F 10 \u002F 15fps) と幅を選択",[63,3061,3062],{},"「GIF 化を開始する」をクリック",[63,3064,2897],{},[28,3066,3067],{"id":3067},"サイズを抑えるコツ",[11,3069,3070],{},"GIF は形式として大きくなりがちです。以下の指針で調整してください。",[87,3072,3073,3079,3085,3091],{},[63,3074,3075,3078],{},[38,3076,3077],{},"区間は短く",": 3〜6 秒が実用上の上限",[63,3080,3081,3084],{},[38,3082,3083],{},"幅は 480px 以下",": Slack・Twitter で使うなら 480px 前後で十分",[63,3086,3087,3090],{},[38,3088,3089],{},"フレームレートは 10fps",": 15fps 以上は体感差が小さくサイズだけ増える",[63,3092,3093,3096],{},[38,3094,3095],{},"色数は制限",": ツール側で最適化しているが、単調な色味の動画ほどうまくハマる",[28,3098,388],{"id":388},[11,3100,3101,3102,3105,3106,3109],{},"ffmpeg.wasm で動画を復号し、",[23,3103,3104],{},"palettegen"," と ",[23,3107,3108],{},"paletteuse"," フィルタを使って GIF の 256 色パレットに最適化して書き出しています。",[87,3111,3112,3114,3120,3126],{},[63,3113,2930],{},[63,3115,3116,3119],{},[23,3117,3118],{},"-vf \"fps=10,scale=480:-1:flags=lanczos,palettegen\""," で最適パレット生成",[63,3121,3122,3125],{},[23,3123,3124],{},"-vf \"fps=10,scale=480:-1:flags=lanczos,paletteuse\""," で GIF エンコード",[63,3127,3128],{},"Blob としてメモリに展開",[11,3130,3131],{},"2 パス処理をブラウザ内で完結させているため、サーバー送信は一切発生しません。",[28,3133,190],{"id":190},[11,3135,3136,3139,3140,3142],{},[38,3137,3138],{},"Q. 長い動画を GIF にするとサイズがとても大きくなる","\nA. GIF は非可逆ですが圧縮効率は動画形式より大幅に劣ります。30 秒以上の場合は ",[18,3141,2987],{"href":20}," で軽量 MP4 のままにするのがお勧めです。",[11,3144,3145,3148],{},[38,3146,3147],{},"Q. 音声は入りますか？","\nA. GIF 仕様上、音声は含められません。音声付きで共有したいなら動画のままが適切です。",[11,3150,3151,3154],{},[38,3152,3153],{},"Q. 透過 GIF は作れますか？","\nA. 1 ビット透過なら可能ですが、動画ソースからの抽出は実用的でないため、本ツールでは非対応です。",[28,3156,217],{"id":217},[87,3158,3159,3164,3169],{},[63,3160,3161,3163],{},[18,3162,232],{"href":231}," — GIF 化前に必要な区間だけ切り出す",[63,3165,3166,3168],{},[18,3167,2987],{"href":20}," — GIF の代わりに軽量 MP4 にする選択肢",[63,3170,3171,3173],{},[18,3172,239],{"href":238}," — 他形式への変換",{"title":245,"searchDepth":246,"depth":246,"links":3175},[3176,3177,3178,3179,3180,3181],{"id":3030,"depth":246,"text":3031},{"id":55,"depth":246,"text":55},{"id":3067,"depth":246,"text":3067},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の 動画 → GIF 変換ツールは、動画をサーバーに送らずブラウザ内で GIF アニメに変換します。SNS・ドキュメント・Slack 用の短尺アニメ作成に。Zerosend 編集部が解説。",{},"\u002Fblog\u002Fvideo-to-gif-intro",{"title":3017,"description":3182},"video-to-gif-intro","blog\u002Fvideo-to-gif-intro",[273,3189,275],"GIF","YqVtzywNXMoliy5XfKyh8G6oMk94tuk4-sQL7-9g0uE",{"id":3192,"title":3193,"author":6,"body":3194,"category":259,"coverImage":260,"description":3324,"draft":262,"extension":263,"locale":264,"meta":3325,"navigation":266,"noindex":262,"path":3326,"publishedAt":268,"seo":3327,"slug":3328,"stem":3329,"tags":3330,"updatedAt":268,"__hash__":3331},"blog\u002Fblog\u002Fvideo-trim-intro.md","動画をトリミング (切り出し) する — \u002Ftools\u002Fvideo-trim の思想と使い方",{"type":8,"value":3195,"toc":3317},[3196,3199,3204,3206,3213,3216,3218,3237,3239,3247,3263,3266,3268,3276,3281,3287,3298,3300],[11,3197,3198],{},"60 分の会議録画から「重要な 3 分」だけ共有したい、旅行動画の最初の手ブレ部分をカットしたい、画面録画の誤操作部分を除きたい。動画のトリミングは、共有前の定番作業です。",[11,3200,3201,292],{},[18,3202,3203],{"href":231},"Zerosend の動画トリミングツール",[28,3205,502],{"id":502},[11,3207,3208,3209,3212],{},"トリミングしたい動画ほど「切り取りたい箇所」より「切り捨てたい箇所」が大きいものです。60 分の会議録画から 3 分を抽出する場合、",[38,3210,3211],{},"残りの 57 分分の機密発言もいったん相手サーバーにアップロードする","ことになります。",[11,3214,3215],{},"これはプライバシー観点で非合理的です。Zerosend はトリミング処理をローカルで行うため、アップロードそのものが発生しません。入力動画が数 GB あっても、ネットワークには何も流れません。",[28,3217,55],{"id":55},[60,3219,3220,3226,3229,3232,3234],{},[63,3221,3222,69],{},[18,3223,3224],{"href":231},[23,3225,231],{},[63,3227,3228],{},"動画をドラッグ&ドロップ",[63,3230,3231],{},"開始時刻・終了時刻を指定 (スライダーまたは秒数入力)",[63,3233,531],{},[63,3235,3236],{},"切り出された動画をダウンロード",[28,3238,388],{"id":388},[11,3240,539,3241,3243,3244,3246],{},[23,3242,542],{}," (開始) \u002F ",[23,3245,546],{}," (終了) オプションを使って指定区間を切り出します。",[87,3248,3249,3251,3257],{},[63,3250,2930],{},[63,3252,3253,3256],{},[23,3254,3255],{},"-ss \u003Cstart> -i input.mp4 -to \u003Cend> -c copy output.mp4"," で再エンコードなしに切り出し",[63,3258,3259,3262],{},[23,3260,3261],{},"-c copy"," によりロスレス抽出 (処理も高速)",[11,3264,3265],{},"再エンコードしないため、画質劣化なし・処理時間も入力サイズの数%程度で完了します。",[28,3267,190],{"id":190},[11,3269,3270,2969,3273,3275],{},[38,3271,3272],{},"Q. フレーム単位の精度は？",[23,3274,3261],{}," でキーフレーム境界に揃える仕様のため、GOP サイズに依存します。秒単位以上の精度が必要なら問題なく使えますが、フレーム単位の精度が必要な場合は本ツール内で再エンコードオプションを有効化できます (処理時間が増加)。",[11,3277,3278,3280],{},[38,3279,603],{},"\nA. 現状は 1 区間のみです。複数区間を扱う場合は 1 区間ずつ抽出後、別途結合ツールを使ってください。",[11,3282,3283,3286],{},[38,3284,3285],{},"Q. 音声も一緒に切り出される？","\nA. はい。映像と音声は同じ区間でセット抽出されます。",[11,3288,3289,2969,3292,3294,3295,3297],{},[38,3290,3291],{},"Q. 音声だけ切り出したい場合は？",[18,3293,455],{"href":454}," を使うか、本ツールで切り出した動画から音声だけを ",[18,3296,566],{"href":290}," で抽出してください。",[28,3299,217],{"id":217},[87,3301,3302,3307,3312],{},[63,3303,3304,3306],{},[18,3305,2987],{"href":20}," — トリミング後にサイズ削減",[63,3308,3309,3311],{},[18,3310,225],{"href":224}," — 短い区間を GIF アニメに",[63,3313,3314,3316],{},[18,3315,239],{"href":238}," — 形式違いへの変換",{"title":245,"searchDepth":246,"depth":246,"links":3318},[3319,3320,3321,3322,3323],{"id":502,"depth":246,"text":502},{"id":55,"depth":246,"text":55},{"id":388,"depth":246,"text":388},{"id":190,"depth":246,"text":190},{"id":217,"depth":246,"text":217},"Zerosend の動画トリミングツールは、動画をサーバーに送らずブラウザ内で任意の区間だけ切り出します。不要な前後や長い会議録画から特定区間のみを共有したいときに。Zerosend 編集部が解説。",{},"\u002Fblog\u002Fvideo-trim-intro",{"title":3193,"description":3324},"video-trim-intro","blog\u002Fvideo-trim-intro",[273,663,275],"8zr5o8WM7ESnodQXy1hA-lSiHMRDYhYhAQP2mSkA4vQ",{"id":3333,"title":3334,"author":6,"body":3335,"category":260,"coverImage":260,"description":3468,"draft":262,"extension":263,"locale":264,"meta":3469,"navigation":266,"noindex":262,"path":3470,"publishedAt":3471,"seo":3472,"slug":3473,"stem":3474,"tags":3475,"updatedAt":3471,"__hash__":3477},"blog\u002Fblog\u002Ffavicon-generator-intro.md","ブラウザだけで作るファビコン一式 — \u002Ftools\u002Ffavicon-generator の舞台裏",{"type":8,"value":3336,"toc":3461},[3337,3340,3343,3350,3353,3356,3405,3409,3416,3419,3439,3446,3449,3452,3455],[28,3338,3339],{"id":3339},"背景",[11,3341,3342],{},"サイトのファビコンを更新する作業は、新規サイトでも既存サイトのリブランディングでも発生します。ロゴ画像 1 枚から必要なアイコンセットを揃えるのは地味に手間のかかる工程です。",[11,3344,3345,3349],{},[18,3346,3348],{"href":3347},"\u002Ftools\u002Ffavicon-generator","Zerosend のファビコン生成ツール"," は、この工程をブラウザ内で完結させます。ロゴ画像を外部に送らずに一式を作成できるので、NDA 下の受託案件や未公開のブランディング作業でも安心して使えます。",[28,3351,3352],{"id":3352},"何が出力されるか",[11,3354,3355],{},"1 枚の画像 (PNG \u002F JPG \u002F WebP \u002F SVG) から次の 9 ファイルを生成し、ZIP で配布します。",[87,3357,3358,3364,3375,3381,3390,3395],{},[63,3359,3360,3363],{},[23,3361,3362],{},"favicon.ico"," — 16 \u002F 32 \u002F 48px のマルチサイズ ICO",[63,3365,3366,543,3369,543,3372],{},[23,3367,3368],{},"favicon-16.png",[23,3370,3371],{},"favicon-32.png",[23,3373,3374],{},"favicon-48.png",[63,3376,3377,3380],{},[23,3378,3379],{},"apple-touch-icon.png"," (180×180)",[63,3382,3383,543,3386,3389],{},[23,3384,3385],{},"icon-192.png",[23,3387,3388],{},"icon-512.png"," (PWA)",[63,3391,3392],{},[23,3393,3394],{},"site.webmanifest",[63,3396,3397,3400,3401,3404],{},[23,3398,3399],{},"snippet.html"," — ",[23,3402,3403],{},"\u003Chead>"," に貼り付ける link タグ",[28,3406,3408],{"id":3407},"ico-を自前で書き出す","ICO を自前で書き出す",[11,3410,3411,3412,3415],{},"PNG は Canvas API で簡単に書き出せますが、ICO は少し工夫が必要です。とはいえ、Windows Vista 以降の ICO は ",[38,3413,3414],{},"PNG バイト列をそのまま埋め込める"," ため、意外と単純です。",[11,3417,3418],{},"構造:",[87,3420,3421,3427,3433],{},[63,3422,3423,3426],{},[38,3424,3425],{},"ICONDIR"," (6 バイト): reserved \u002F type \u002F image count",[63,3428,3429,3432],{},[38,3430,3431],{},"ICONDIRENTRY"," (16 バイト × 画像数): 幅 \u002F 高さ \u002F bpp \u002F サイズ \u002F オフセット",[63,3434,3435,3438],{},[38,3436,3437],{},"画像データ",": PNG のバイト列を順に連結",[11,3440,3441,3442,3445],{},"実装は依存ゼロで 30 行程度に収まります。",[23,3443,3444],{},"domain\u002Fprocessors\u002FfaviconGenerator.ts"," で実装を公開しています。",[28,3447,3448],{"id":3448},"検証の楽しさ",[11,3450,3451],{},"作ったあとは DevTools の Network タブで確認できます。画像選択 → 生成 → ダウンロードの全てで、あなたのロゴが外に出ないことを自分で検証できます。",[28,3453,3454],{"id":3454},"まとめ",[11,3456,3457,3458,1017],{},"1 枚の画像から ICO \u002F PNG \u002F apple-touch-icon \u002F manifest \u002F HTML スニペットを、あなたの端末だけで生成できます。",[18,3459,3460],{"href":3347},"試してみてください",{"title":245,"searchDepth":246,"depth":246,"links":3462},[3463,3464,3465,3466,3467],{"id":3339,"depth":246,"text":3339},{"id":3352,"depth":246,"text":3352},{"id":3407,"depth":246,"text":3408},{"id":3448,"depth":246,"text":3448},{"id":3454,"depth":246,"text":3454},"1 枚の画像から ICO \u002F PNG \u002F apple-touch-icon \u002F site.webmanifest を生成するファビコン生成ツールを公開しました。ICO フォーマットを自前で書き出す実装のポイントを紹介します。",{},"\u002Fblog\u002Ffavicon-generator-intro","2026-04-19",{"title":3334,"description":3468},"favicon-generator-intro","blog\u002Ffavicon-generator-intro",[275,3476],"技術解説","j9H-wD4jISIIEFGU6QcADLgjb5CJ4w4V8exyY2whrb0",{"id":3479,"title":3480,"author":6,"body":3481,"category":260,"coverImage":260,"description":3550,"draft":262,"extension":263,"locale":264,"meta":3551,"navigation":266,"noindex":262,"path":3552,"publishedAt":3471,"seo":3553,"slug":3554,"stem":3555,"tags":3556,"updatedAt":3471,"__hash__":3558},"blog\u002Fblog\u002Fwelcome.md","Zerosend ブログを始めます",{"type":8,"value":3482,"toc":3544},[3483,3486,3489,3492,3495,3515,3518,3534,3536],[28,3484,3485],{"id":3485},"はじめに",[11,3487,3488],{},"Zerosend の公式ブログを開始します。このブログでは、プライバシーファーストな Web ツールを作る中で得た知見、ブラウザ内処理の技術、そしてデータを「送らない」という選択についての考察を記録していきます。",[28,3490,3491],{"id":3491},"扱うテーマ",[11,3493,3494],{},"主に次のテーマを扱います。",[87,3496,3497,3503,3509],{},[63,3498,3499,3502],{},[38,3500,3501],{},"ブラウザ内処理の技術",": WebAssembly、Web Worker、Canvas API、File System Access API の実用例",[63,3504,3505,3508],{},[38,3506,3507],{},"プライバシー設計",": CSP、アップロード不要のアーキテクチャ、Network タブで検証できる実装",[63,3510,3511,3514],{},[38,3512,3513],{},"各ツールの舞台裏",": 画像圧縮 \u002F PDF 編集 \u002F 動画変換 \u002F ファビコン生成などの内部実装",[28,3516,3517],{"id":3517},"更新頻度",[11,3519,3520,3521,3524,3525,543,3529,3533],{},"不定期ですが、ツールの追加・改善に合わせて更新します。記事の一覧は ",[18,3522,3523],{"href":3523},"\u002Fblog"," から、または ",[18,3526,3528],{"href":3527},"\u002Fblog\u002Ffeed.xml","RSS",[18,3530,3532],{"href":3531},"\u002Fblog\u002Ffeed.json","JSON Feed"," で購読できます。",[28,3535,3454],{"id":3454},[11,3537,3538,3539,3543],{},"まずはこの 1 本から。引き続き ",[18,3540,3542],{"href":3541},"\u002F","Zerosend"," のツール群もよろしくお願いします。",{"title":245,"searchDepth":246,"depth":246,"links":3545},[3546,3547,3548,3549],{"id":3485,"depth":246,"text":3485},{"id":3491,"depth":246,"text":3491},{"id":3517,"depth":246,"text":3517},{"id":3454,"depth":246,"text":3454},"ブラウザ内で完結するプライバシーファーストなオンラインツールを配信する Zerosend の公式ブログを開始します。扱うテーマと更新頻度について説明します。",{},"\u002Fblog\u002Fwelcome",{"title":3480,"description":3550},"welcome","blog\u002Fwelcome",[3557],"お知らせ","FVc0WPWmjeXo6BrnFdlDampwoyA6OVHbMm-JUXveuFc",{"id":3560,"title":3561,"author":6,"body":3562,"category":260,"coverImage":260,"description":3684,"draft":262,"extension":263,"locale":264,"meta":3685,"navigation":266,"noindex":262,"path":3686,"publishedAt":3471,"seo":3687,"slug":3688,"stem":3689,"tags":3690,"updatedAt":3471,"__hash__":3693},"blog\u002Fblog\u002Fwhy-browser-only.md","なぜ Zerosend はブラウザ内処理にこだわるのか",{"type":8,"value":3563,"toc":3677},[3564,3568,3571,3578,3581,3584,3611,3614,3617,3620,3631,3638,3641,3644,3664,3667,3669],[28,3565,3567],{"id":3566},"なぜ送らないのか","なぜ「送らない」のか",[11,3569,3570],{},"オンラインツールの多くはファイルをサーバーに送信して処理します。利便性は高いものの、ユーザーは自分のファイルがサーバー上でどう扱われるかを自分の目で確認できません。",[11,3572,3573,3574,3577],{},"Zerosend の設計原則はシンプルです。",[38,3575,3576],{},"「送らないのが一番確実」","。ファイルを外に出さなければ、ログも、漏洩も、第三者共有も原理的に存在しません。",[28,3579,3580],{"id":3580},"ブラウザ内処理で何ができるか",[11,3582,3583],{},"現代のブラウザは、かつてネイティブアプリが担っていた処理の多くを実行できます。",[87,3585,3586,3589,3592,3599],{},[63,3587,3588],{},"Canvas API による画像圧縮・リサイズ・形式変換",[63,3590,3591],{},"WebAssembly + ffmpeg による動画・音声の変換",[63,3593,3594,543,3596,3598],{},[23,3595,1576],{},[23,3597,1748],{}," による PDF の結合・分割・ラスタライズ",[63,3600,3601,543,3604,543,3607,3610],{},[23,3602,3603],{},"File System Access API",[23,3605,3606],{},"Blob",[23,3608,3609],{},"URL.createObjectURL"," を介したダウンロード",[11,3612,3613],{},"これらは全てクライアントサイドで完結します。",[28,3615,3616],{"id":3616},"ユーザーが検証できる透明性",[11,3618,3619],{},"「送っていません」という主張は、ユーザーが自分で確認できなければ信用するしかありません。Zerosend はこれを自動検証できる形にしています。",[60,3621,3622,3625,3628],{},[63,3623,3624],{},"ブラウザで DevTools を開く",[63,3626,3627],{},"Network タブを開いたままツールを使う",[63,3629,3630],{},"処理中にアップロードらしきリクエストが出ないことを確認する",[11,3632,3633,3634,3637],{},"CDN や解析スクリプトへの最小限の通信は残りますが、",[38,3635,3636],{},"処理対象のファイル自体が HTTP リクエストのボディに乗らない","ことは目視で確認できます。",[28,3639,3640],{"id":3640},"制約もある",[11,3642,3643],{},"ブラウザ内処理は万能ではありません。",[87,3645,3646,3652,3658],{},[63,3647,3648,3651],{},[38,3649,3650],{},"ファイルサイズの上限",": メモリに載る範囲で処理する必要がある",[63,3653,3654,3657],{},[38,3655,3656],{},"初回ロードが重い",": ffmpeg.wasm は約 30MB の WASM を取得する",[63,3659,3660,3663],{},[38,3661,3662],{},"複雑な処理はサーバーが速い",": 大規模な機械学習推論はまだブラウザには重い",[11,3665,3666],{},"Zerosend は「日常的な軽作業をブラウザで完結させる」範囲に絞ることで、この制約の中で価値を出せるようにしています。",[28,3668,3454],{"id":3454},[11,3670,3671,3672,3676],{},"「送らない」は、透明性と検証可能性をユーザーに返す設計です。詳しい技術背景は ",[18,3673,3675],{"href":3674},"\u002Fguide\u002Fprivacy-online-tools","ピラー記事"," も参照してください。",{"title":245,"searchDepth":246,"depth":246,"links":3678},[3679,3680,3681,3682,3683],{"id":3566,"depth":246,"text":3567},{"id":3580,"depth":246,"text":3580},{"id":3616,"depth":246,"text":3616},{"id":3640,"depth":246,"text":3640},{"id":3454,"depth":246,"text":3454},"ファイルをサーバーにアップロードしない設計を選んだ理由と、ブラウザ内処理の利点・制約を整理します。DevTools の Network タブで自ら検証できる透明性について書きました。",{},"\u002Fblog\u002Fwhy-browser-only",{"title":3561,"description":3684},"why-browser-only","blog\u002Fwhy-browser-only",[3691,3692],"プライバシー","設計","lqogv5W41hd3KXZhnuHda2B25OSBrkZ2aRBaPDbdFhQ",1776723679396]