画像リソースが同一ドメイン下にないために、キャンバスがクロスドメインで汚染される場合の解決策
2022-01-31 03:10:45
背景画像と動的に生成されるQRコードを含む画像を描きたい。ただし、背景画像はプロジェクト自体の静的リソースで、QRコードはサーバーによって動的に生成され、両者は同じドメイン下にないことが条件となる。
回避策:同じドメイン名の下にあるすべての画像をリダイレクトします。
let count = 0;
let bgImg = document.createElement('img');
let qrImg = document.createElement('img');
bgImg.src = redirectUrl('x.png');
qrImg.src = redirectUrl('y.png');
[bgImg, qrImg].forEach((e) => {
e.onload = () => {
count ++;
if (count === 2) {
drawerImg(bgImg, qrImg);
}
}
})
function redirectUrl (url) {
return 'https://xxx/view?fileUrl=' + encodeURIComponent(url);
}
function drawerImg (imgContent, qrContent, scaleBy = 2) {
let {bgImgW, bgImgH} = {375, 800};
let {qrx, qry, qrw, qrh} = {20, 700, 50, 50};
let Canvas = document.createElement('canvas');
let ctx = Canvas.getContext("2d");
Canvas.width = bgImgW * scaleBy;
Canvas.height= bgImgH * scaleBy;
ctx.drawImage(imgContent, 0, 0, bgImgW * scaleBy, bgImgH * scaleBy);
ctx.drawImage(qrContent, qrx * scaleBy, qry * scaleBy, qrw * scaleBy, qrh * scaleBy);
let nodeI = document.createElement("img");
nodeI.src = Canvas.toDataURL();
document.body.appendChild(nodeI)
}
以上、本記事の全内容をご紹介しましたが、皆様の学習のお役に立てれば幸いです。また、Script Houseをより一層応援していただければ幸いです。
関連
-
Html5 データストリームによる動画再生
-
html5対応ブラウザの確認方法
-
Canvasでグラフィックス/イメージバインディングのイベントリスナーを実装する方法
-
iPhoneXの画面適応 WeChatアプリとH5でセーフエリア下部の小さな黒いバー
-
Html5によるマンドモバイル活用の甌穴(おうけつ)踏査
-
HTML5 Canvasタグの解説と基本的な使い方
-
data:画像データのurlファイルをBlobアップロードバックエンドメソッドに渡す。
-
html5 postMessageのフロントエンドクロスドメインとフロントエンドのリスニング方式の例
-
Canvas wave garlandのサンプルコード
-
ivxプラットフォーム開発:9箱の抽選機能をコードレスで実装する。
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
Canvasでイベントを追加する方法を説明する
-
キャンバスは、ビデオの最初のサムネイルを取得します。
-
シェアボタン付きAmazeUIボトムナビゲーションバー用サンプルコード
-
html5 on outbound embedded page 通信問題 (postMessage でクロスドメイン通信を解決)
-
h5モバイルコール Alipay、WeChat決済の実装
-
h5ページ evokeアプリがインストールされていない場合、ダウンロードにジャンプします(iOS、Android)。
-
HTML5+CSSでfloatを設定しても、真ん中や間違った行の代わりに移動しない問題
-
Html5ページオープンアプリに関するいくつかの考察
-
円形のプログレスバーを生成する html svg
-
window.openがブラウザにブロックされている場合の解決策を詳しく説明します。