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

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

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

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

HTML5

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

JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

1回答

8368閲覧

ローカルにあるファイルをcanvasに描画し、 そのあと toDataURL圧縮したjpeg形式のURLに変換したい

gyouza

総合スコア12

canvas

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

HTML5

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

JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2017/01/20 21:30

###前提・実現したいこと
javascript(Jquery)でローカルにあるファイルをcanvasに描画し、
そのあと toDataURLでcanvasの画像を圧縮したjpeg形式のURLに変換したいです。

###発生している問題・エラーメッセージ
canvasに描画したdataを toDataURLで変換する際に
以下のエラーが起こっています。

エラーメッセージ

canvas_sample.html:51 Uncaught TypeError: canvas.toDataURL is not a function
at HTMLButtonElement.<anonymous> (canvas_sample.html:51)
at HTMLButtonElement.dispatch (jquery-2.1.4.min.js:3)
at HTMLButtonElement.r.handle (jquery-2.1.4.min.js:3)

###該当のソースコード

<body> <div id="drawArea"> <canvas id="myCanvas" width="400" height="300"></canvas> </div> <div id="uploadArea"> <input id="uploadFile" name="image" type="file" accept="image/*" capture="camera" /> </div> <div> <button id="todataurl">todataURL</button> </div> <script> var canvas = $("#myCanvas"); var ctx = canvas[0].getContext("2d"); $("#uploadFile").change(function() { ctx.clearRect(0, 0, canvas.width, canvas.height); // 選択されたファイルを取得 var file = this.files[0]; var image = new Image(); var reader = new FileReader(); // File APIを使用し、ローカルファイルを読み込む reader.onload = function(evt) { // 画像がloadされた後に、canvasに描画する image.onload = function() { var image_w = image.width var image_h = image.height ctx.drawImage(image, 0, 0, image_w, image_h, 0, 0, 400, 300); } // 画像のURLをソースに設定 image.src = evt.target.result; // console.log(image.src); } //ファイルを読み込み、データをBase64でエンコードされたデータURLにして返す reader.readAsDataURL(file); }); //canvasの画像をjpage形式のURLに変換 $("#todataurl").click(function(){ var dataUrl = canvas.toDataURL("image/jpeg", 0.4); console.log(dataUrl); }); </script> </body>

###試したこと
課題に対してアプローチしたことを記載してください
HTMLButtonElement.<anonymous> + toDataURLなどで検索してみましたが
解決方法がみつかりませんでした。

###補足情報(言語/FW/ツール等のバージョンなど)
より詳細な情報
jquery-2.1.4

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

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

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

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

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

guest

回答1

0

ベストアンサー

var canvas = $("#myCanvas");とあるとおり、canvasjQueryオブジェクトです。対して、toDataURL()はcanvasのDOM Elementオブジェクト(正確にはcanvas用のHTMLCavnasElementオブジェクト)のメソッドになります。そのため、jQueryオブジェクトに対してメソッドを呼び出してもうまくいきません。jQueryオブジェクトからDOM Elementオブジェクトを取り出し、それに対してメソッドを呼び出す必要があります。

その方法は、すでにctxを取得するところでやっています。そう、添字0でアクセスする、つまり、canvas[0].toDataURL("image/jpeg", 0.4)とするだけです。

jQueryは一見便利ですが、常にjQueryオブジェクトとDOM Elementオブジェクトの違いを意識してください。相互に変換は可能ですが、それぞれ使用できる物が違いますので、時には変換しながら使う必要があります。

投稿2017/01/20 22:21

編集2017/01/20 22:22
raccy

総合スコア21735

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

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

gyouza

2017/01/21 00:32

ありがとうございます!解決しました。わかりやすく説明していただきありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問