ユーザー入力を取り、工学計算を行い、フォーマットされたレポートまたはグラフィックを表示するWebアプリケーションを開発しています。グラフィックは工学図であり、円グラフのような標準的なグラフであるとは限りません。アプリケーションの主な機能は、ユーザーがこれらの図をブラウザからWordまたはExcelドキュメントにコピーできるようにすることです。
クライアントで生成されたSVGを使用するか、サーバー側で生成されたビットマップを使用するかを選択する必要があります。私はSVGアプローチを好み、プロトタイピングは適切に見えますが、SVGグラフのコピーは、特にグラフがdivに表示されている場合(つまり、ページ全体が.svgではない場合)、ブラウザー間で一貫してサポートされていないようです。たとえば、IEはドロップダウンに「コピー」を表示しますが、SVGグラフィックの一部のみをクリップボードにコピーします。Chromeは、 SVGグラフィックを右クリックします。
私がググってみたら、WebアプリケーションからクリップボードにSVG画像を取得する際の問題に関する情報が少ないことに驚きます。
私の質問この問題を解決した読者:
JavaScriptを使用して、より大きなDOMの一部であるSVG要素をクリップボードに取得する一貫した方法はありますか。
ブラウザからクリップボードにグラフィックスを取得するという私の要件に基づく他の推奨事項はありますか?
svg
をsvg要素として表示する代わりに、img
タグで表示します。これにはいくつかの制限があります(カスタムフォントや埋め込みスクリプトを表示することはできませんが、これはユースケースではないようです)。利点は、画像から期待するとおりに動作することです(ドラッグアンドドロップ、右クリックアンドコピーなどが可能)。
これを行うには、base64でエンコードする必要があります。あなたはそれをjsでサーバーサイドまたはクライアントサイドで行うことができます。イメージタグは次のようになります...
<img src="" width="..." height="..." alt="diagram" />
どこ R0lGODlhEAAQAMQ...
はbase64でエンコードされたsvgです。
Javascriptとクリップボードはa **の問題です。
私が知っているあなたの状況に対する1つの回避策があります:
それが本当のSVGファイルである場合、Chromeで画像を右クリックし、[要素の検査]を選択します。ブラウザーコンソールが開き、インスペクターで選択できるSVG要素が開きます。インスペクターでsvgタグを右クリックし、「コピー」または「HTMLとしてコピー」を選択します(選択を正確に思い出せません)
そのテキストをテキストファイルに貼り付け、SVG拡張子を付けてファイルを保存します。その後、任意のブラウザまたはSVG編集プログラムで開くことができます。 Inkscape は、XMLスタイルエディターでSVGファイル全体を表示および編集できるため、編集およびデバッグに適しています。
**申し訳ありません-リクエストの最初の部分を逃しました。それはトリッキーになります。私はその部分を手伝うことができないと思います。ただし、コピーアンドペーストはおそらく最善の方法ではありません。 SVGファイルとExcelファイルの両方を操作するためのPHPクラスがあり、それがおそらく進むべき道でしょう。
SVGコンテンツをプレーンXMLテキストとしてクリップボードにコピーできましたが、Inkscape(SVGでの作業に使用)が クリップボード内のテキストをSVGとして認識しない であるため、役に立たないように見えました。 SVGのテキストをコピーするだけでは不十分で、ブラウザはmime-typeをimage/svg+xml
に設定する必要があります。
HTML5クリップボードAPIでいくつかのトリックを試しましたが、ChromeはMIMEタイプをシステムクリップボードにエクスポートできません。関連するバグレポートとjsfiddleリンクがここにあります- https://code.google.com/p/chromium/issues/detail?id=5047
プロジェクトで同じ問題に直面しました。顧客は、かなり複雑なチャートを望んでいました。 svgを使用して開発することにしました。完璧に機能しましたが、顧客はグラフを画像としてダウンロードできることを望んでいました。インターネットで検索したところ、saveSvgAsPng( https://www.npmjs.com/package/save-svg-as-png )が見つかりました。それは私たちにとってトリックでした。
グラフはこのようなページにあります:
<svg id="graph1" style="width: 700px; height: 700px">
....
.....
...
</svg>
グラフは表示されますが、ダウンロードやコピーはできません。だから、ここに私が取ったステップがあります:
<script src="/path/to/lib/save-svg-as-png/lib/saveSvgAsPng.js"></script>
<svg id="graph1" style="width: 700px; height: 700px; display: none">
<!-- // code goes here -->
</svg>
<img id="graph1_as_png" src="" width="700" height="700" style="display: none">
<script>
svgAsPngUri(document.getElementById("graph1")).then(uri => {
$("#graph1_as_png").attr('src', uri).show();
});
</script>
2番目のイメージのソースは、svgのBASE64エンコードバージョンで埋められます。変換後、画像が表示されます。これで、svgイメージとまったく同じイメージができましたが、イメージをダウンロードまたはコピーする可能性があります。
これがあなたの役に立つことを願っています。