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

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

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

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

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

WebRTC

WebRTC(Web Real-Time Communication)とは、プラグイン無しでウェブブラウザ間の音声通話・ビデオチャットなどリアルタイムコミュニケーションができるオープンフレームワークです。W3CがAPIレベルで、IETFがプロトコルレベルでそれぞれ標準化が進められています。

Q&A

解決済

1回答

7598閲覧

iPhone・iPadからアクセスしたwebRTCの画像サイズを知りたい

hokosugi

総合スコア63

canvas

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

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

WebRTC

WebRTC(Web Real-Time Communication)とは、プラグイン無しでウェブブラウザ間の音声通話・ビデオチャットなどリアルタイムコミュニケーションができるオープンフレームワークです。W3CがAPIレベルで、IETFがプロトコルレベルでそれぞれ標準化が進められています。

0グッド

0クリップ

投稿2018/12/30 01:16

webRTCでアクセスした映像からcanvasで画像を撮るアプリを作成中です。

通常、PCブラウザカメラの画像サイズはwidth:1280,height:720などの横長サイズですが、videoタグにサイズ指定を入れずにiPhone・iPadからsafari経由でアクセスすると縦長サイズになってしまいます。iPhone・iPadからの画像もpcブラウザカメラと同様の横長サイズで取得したいのですが、videoタグのサイズを横長に指定すると(下記のようにwidth:640,height:360)そのサイズの中で縦長になってしまいます。詳しいことは分かりませんがiPhone・iPadのカメラサイズが変更できない仕様なんだと思います。

$(function() { navigator.mediaDevices = navigator.mediaDevices || ((navigator.mozGetUserMedia || navigator.webkitGetUserMedia) ? { getUserMedia: function(c) { return new Promise(function(y, n) { (navigator.mozGetUserMedia || navigator.webkitGetUserMedia).call(navigator, c, y, n); }); } } : null); if (!navigator.mediaDevices) { alert("getUserMedia() not supported."); return; } else { console.log("success") } // Prefer camera resolution nearest to 1280x720. var constraints = { audio: false, video: { advanced: [ { width: 1280 }, { height: 720 }, { facingMode: 'environment' } ]} }; // alert(constraints) navigator.mediaDevices.getUserMedia(constraints).then(function(stream) { video = document.getElementById('camera'); // videoの縦幅横幅を取得 video.width = 640; video.height = 360; video.srcObject = stream; }).catch(function(err) { console.log(err.name + ": " + err.message); });

そこでiPhone・iPadで撮影されたcanvasに落とした画像を加工・変形してpcブラウザカメラの画像サイズに合わせるやり方にしようと考えて

var canvas = document.getElementById('canvas'); //canvasの描画モードを2dに var ctx = canvas.getContext('2d'); canvas.setAttribute("width", 540); canvas.setAttribute("height", 360); ctx.drawImage(video, 0, 0, 540, 360, 0, 0, 540, 360)

のようにcanvas.drawImageで画像を切り取り拡大・縮小・変形させて横長サイズに落とし込むようにしましたが、切り取るための元映像の画像サイズが分からないため上手く調整がいきません。画像のサイズを取得したいのですがどうすればよいでしょうか?

videoタグにサイズ指定をしないとフル画面でカメラ画像を取得できますが、サイズ指定がしていないせいかvideo.width video.heightとも0が返ってきますし、サイズ指定してやるとサイズの中で調整された縦長のサイズが読み取れません。

よろしくお願いします。

`

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

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

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

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

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

guest

回答1

0

ベストアンサー

<video>タグから画像サイズを取得するときは、video.width, video.heightではなく、video.videoWidth, video.videoHeightから取得できます。

あるいは、

js

1navigator.mediaDevices.getUserMedia(constraints).then(function(stream) { 2 var settings = stream.getVideoTracks()[0].getSettings(); 3 var width = settings.width; 4 var height = settings.height; 5});

のようにして、getUserMediaで取得したメディアストリームから直接画像サイズを取得することも可能です。

投稿2019/01/10 03:28

othersight

総合スコア356

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

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

hokosugi

2019/01/10 11:52

ご回答ありがとうございました。 スマホサイズ(720x1280)が取得でしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問