質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
canvas

HTML5の<canvas>要素用のタグです。CanvasはHTML5から導入された、二次元の図形描写が可能な要素です。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

2回答

1268閲覧

画像上に文字を書きたい

TNKa

総合スコア5

canvas

HTML5の<canvas>要素用のタグです。CanvasはHTML5から導入された、二次元の図形描写が可能な要素です。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2020/02/09 07:27

前提・実現したいこと

実現したいことは、選択した画像ファイルの上に文字を書きたいです。
実際にできていることは下のコードのもので画像表示と表示した画像をクリアすることができます。

<!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <title></title> <script> window.onload = () => { const file = document.getElementById('file'); const canvas = document.getElementById('canvas'); const deleteImg = document.getElementById("delete"); let drawing = false; let before_x = 0; let before_y = 0; const canvasWidth = 500; const canvasHeight = 500; let uploadImgSrc; canvas.width = canvasWidth; canvas.height = canvasHeight; const ctx = canvas.getContext('2d'); function loadLocalImage(e) { const fileData = e.target.files[0]; if (!fileData.type.match('image.*')) { alert('画像を選択してください'); return; } const reader = new FileReader(); reader.onload = function () { uploadImgSrc = reader.result; canvasDraw(); } reader.readAsDataURL(fileData); } file.addEventListener('change', loadLocalImage, false); function canvasDraw() { ctx.clearRect(0, 0, canvasWidth, canvasHeight); const img = new Image(); img.src = uploadImgSrc; img.onload = function () { ctx.drawImage(img, 0, 0, canvasWidth, this.height * (canvasWidth / this.width)); } } deleteImg.addEventListener("click", () => { ctx.clearRect(0, 0, canvasWidth, canvasHeight); file.nodeValue = ""; }) } </script> </head> <body> <div class="upload"><input type="file" name="file" id="file"><button id="delete">画像のクリア</button></div> <div id="box"><canvas id="canvas"></canvas> </body> </html>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

canvasやsvgで処理するか、img/figure/figcaptionで処理してもよいでしょう

投稿2020/02/10 03:08

yambejp

総合スコア116734

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

文字を書きたい

ポインティングデバイスで「書く」というのではなく、文字列を画像に重ねるなど「描く」ための方法であれば、MDN に参考になるページがあります。

参考になるでしょうか。

投稿2020/02/09 10:13

AkitoshiManabe

総合スコア5434

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問