![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?e8efa67)
<html>
<head>
<script>
function start1(camela_flag, mike_flag) {
const video = document.getElementById("video")
const audio = document.createElement('audio');
if (camela_flag == 1 && mike_flag == 1) {
navigator.mediaDevices.getUserMedia({
video: true,
audio: true,
}).then(stream => {
video.srcObject = stream;
video.play();
audio.srcObject = stream;
}).catch(e => {
console.log(e);
})
} else if (camela_flag == 1 && mike_flag == 0) {
navigator.mediaDevices.getUserMedia({
video: true,
audio: false,
}).then(stream => {
video.srcObject = stream;
video.play();
audio.srcObject = stream;
audio.stop();
}).catch(e => {
console.log(e)
})
} else if (camela_flag == 0 && mike_flag == 1) {
navigator.mediaDevices.getUserMedia({
video: false,
audio: true,
}).then(stream => {
video.srcObject = null;
video.play();
audio.srcObject = stream;
audio.play();
audio.muted = false;
}).catch(e => {
console.log(e);
})
} else {
navigator.mediaDevices.getUserMedia({
video: false,
audio: false,
}).then(stream => {
video.srcObject = stream;
video.stop();
audio.srcObject = stream;
audio.muted = true;
audio.volume = 0.0;
audio.stop();
}).catch(e => {
console.log(e)
})
}
}
navigator.mediaDevices.ondevicechange = event => {
updateDeviceList();
}
function updateDeviceList() {
navigator.mediaDevices.enumerateDevices()
.then(function (devices) {
elem.innerHTML = "<select>";
elem.innerHTML = "<select>";
devices.forEach(device => {
let elem = document.createElement("option");
let [kind, type, direction] = device.kind.match(/(\w+)(input|output)/i);
elem.innerHTML += "<option value =" + kind + "> " + direction + "</option>";
if (type === "audio") {
audioList.appendChild(elem);
} else if (type === "video") {
videoList.appendChild(elem);
}
});
elem.innerHTML += "</select>";
elem.innerHTML += "</select>";
});
}
</script>
</head>
<body>
<div>
<video id="video"></video>
</div>
<div>
<audio id="audio"></audio>
<input type="button" onclick="start1(1,1);" / value="カメラ&マイクSTART">
<input type="button" onclick="start1(1,0);" / value="カメラSTART">
<input type="button" onclick="start1(0,1);" / value="マイクSTART">
<input type="button" onclick="start1(0,0);" / value="カメラ&マイクSTOP">
<input type="button" onclick="updateDeviceList();" / value="デバイス変更">
</div>
<div>
<audio class="gum" title="audio stream from getUserMedia()" controls></audio>
<div class="outputSelector">
<label>Select audio output: </label>
<select id = "audio"></select>
<select id = "video"></select>
</div>
</div>
</body>
</html>
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript コードレビューをお願いします。 1 2022/07/16 05:38
- JavaScript clear機能を失わずにファイルアップロード機能を作成したい 3 2023/06/10 16:12
- JavaScript アップロードファイルの種類によって処理を分岐させたいのですが書き方が分からずアドバイスお願いします 4 2023/06/17 19:12
- JavaScript switch文のswitch(n)の部分を複数の値にするか、if文に変えてほしいです。 1 2022/07/27 17:18
- JavaScript フォームが空欄の時にフォームの外をクリックすると、エラーが出るコードを調べています。 1 2023/06/25 11:51
- JavaScript console.logがどうしても2つ機能しないのでアドバイスをくださいお願いします 2 2022/07/07 22:13
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- HTML・CSS CSSが効かずどのように指定すれば良いか分からないのでアドバイスお願い致します 2 2023/06/07 12:25
- HTML・CSS ボタンをクリックした時に、入力フォームのすぐ下部に、「入力欄が空白です」というテキストメッセージが表 1 2022/04/27 16:25
- JavaScript javascript作成してます。ラジオボタンで判定するコードを書いてます。 1 2023/07/18 11:03
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
プルダウン 項目が多いので先頭...
-
セレクトを全て選択されていな...
-
Selectの中身をfor文で入れる
-
JQuery selectが反映されない
-
プログラムがうまく動きません...
-
現在時刻を取得してフォームのs...
-
<textarea>にプルダウンを表示...
-
JavaScriptでプルダウンのサイ...
-
プルダウンメニューの項目で1つ...
-
Selectボックスの幅を自動で広...
-
ラジオボタンでポップアップメ...
-
jQuery セレクトボックスで選択...
-
html selectの内容を初期値に戻す
-
CSVファイルを読みこみ、プルダ...
-
javascriptでselectボックスの<...
-
UWSCのIE操作でプルダウンを選...
-
return trueとreturn falseの用...
-
テーブルの行数を可変長にした...
-
<JavaScript>tableタグを入力不...
-
FormのonsubmitでJavaスクリプ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
プルダウン 項目が多いので先頭...
-
Selectボックスの幅を自動で広...
-
Selectの中身をfor文で入れる
-
html selectの内容を初期値に戻す
-
JQuery selectが反映されない
-
jQuery セレクトボックスで選択...
-
CSVファイルを読みこみ、プルダ...
-
セレクトを全て選択されていな...
-
現在時刻を取得してフォームのs...
-
セレクトの値を取得できない
-
リストボックスの項目の順番を...
-
onchange等のイベントハンドラ...
-
テーブルにおける行(セルにプル...
-
onFocusOutが複数回呼ばれる!
-
javascriptでプルダウンメニュ...
-
ブラウザの戻るボタンを押した...
-
<textarea>にプルダウンを表示...
-
javascriptでの2つのプルダウン...
-
selectタグに直接onChangeを書...
-
window.openで新しいタブが開か...
おすすめ情報