123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417 |
- //////////////////////////////////////////////////////////////////////////////////
- //////////////////////////////////////////////////////////////////////////////////
- //////////////////////////////////////////////////////////////////////////////////
- // to query the swf anti cache.
- function srs_get_version_code() { return "1.33"; }
- /**
- * player specified size.
- */
- function srs_get_player_modal() { return 740; }
- function srs_get_player_width() { return srs_get_player_modal() - 30; }
- function srs_get_player_height() { return srs_get_player_width() * 9 / 19; }
- //////////////////////////////////////////////////////////////////////////////////
- //////////////////////////////////////////////////////////////////////////////////
- //////////////////////////////////////////////////////////////////////////////////
- /**
- * update the navigator, add same query string.
- */
- function update_nav() {
- $("#srs_index").attr("href", "index.html" + window.location.search);
- $("#nav_srs_player").attr("href", "srs_player.html" + window.location.search);
- $("#nav_rtc_player").attr("href", "rtc_player.html" + window.location.search);
- $("#nav_rtc_publisher").attr("href", "rtc_publisher.html" + window.location.search);
- $("#nav_srs_publisher").attr("href", "srs_publisher.html" + window.location.search);
- $("#nav_srs_chat").attr("href", "srs_chat.html" + window.location.search);
- $("#nav_srs_bwt").attr("href", "srs_bwt.html" + window.location.search);
- $("#nav_vlc").attr("href", "vlc.html" + window.location.search);
- }
- // Special extra params, such as auth_key.
- function user_extra_params(query, params) {
- var queries = params || [];
- for (var key in query.user_query) {
- if (key === 'app' || key === 'autostart' || key === 'dir'
- || key === 'filename' || key === 'host' || key === 'hostname'
- || key === 'http_port' || key === 'pathname' || key === 'port'
- || key === 'server' || key === 'stream' || key === 'buffer'
- || key === 'schema' || key === 'vhost' || key === 'api'
- ) {
- continue;
- }
- if (query[key]) {
- queries.push(key + '=' + query[key]);
- }
- }
- return queries;
- }
- function is_default_port(schema, port) {
- return (schema === 'http' && port === 80)
- || (schema === 'https' && port === 443)
- || (schema === 'webrtc' && port === 1985)
- || (schema === 'rtmp' && port === 1935);
- }
- /**
- @param server the ip of server. default to window.location.hostname
- @param vhost the vhost of HTTP-FLV. default to window.location.hostname
- @param port the port of HTTP-FLV. default to 1935
- @param app the app of HTTP-FLV. default to live.
- @param stream the stream of HTTP-FLV. default to livestream.flv
- */
- function build_default_flv_url() {
- var query = parse_query_string();
- var schema = (!query.schema)? "http":query.schema;
- var server = (!query.server)? window.location.hostname:query.server;
- var port = (!query.port)? (schema==="http"? 8080:1935) : Number(query.port);
- var vhost = (!query.vhost)? window.location.hostname:query.vhost;
- var app = (!query.app)? "live":query.app;
- var stream = (!query.stream)? "livestream.flv":query.stream;
- var queries = [];
- if (server !== vhost && vhost !== "__defaultVhost__") {
- queries.push("vhost=" + vhost);
- }
- queries = user_extra_params(query, queries);
- var uri = schema + "://" + server;
- if (!is_default_port(schema, port)) {
- uri += ":" + port;
- }
- uri += "/" + app + "/" + stream + "?" + queries.join('&');
- while (uri.indexOf("?") === uri.length - 1) {
- uri = uri.substr(0, uri.length - 1);
- }
- return uri;
- }
- // for the bandwidth tool to init page
- function build_default_bandwidth_rtmp_url() {
- var query = parse_query_string();
- var schema = 'rtmp';
- var server = (!query.server)? window.location.hostname:query.server;
- var port = (!query.port)? 1935:query.port;
- var vhost = "bandcheck.srs.com";
- var app = (!query.app)? "app":query.app;
- var key = (!query.key)? "35c9b402c12a7246868752e2878f7e0e":query.key;
- var uri = schema + "://" + server;
- if (!is_default_port(schema, port)) {
- uri += ":" + port;
- }
- uri += "/" + app + "?key=" + key + "&vhost=" + vhost;
- return uri;
- }
- function build_default_rtc_url(query) {
- // Use target to overwrite server, vhost and eip.
- console.log('?target=x.x.x.x to overwrite server, vhost and eip.');
- if (query.target) {
- query.server = query.vhost = query.eip = query.target;
- query.user_query.eip = query.target;
- delete query.target;
- }
- var server = (!query.server)? window.location.hostname:query.server;
- var vhost = (!query.vhost)? window.location.hostname:query.vhost;
- var app = (!query.app)? "live":query.app;
- var stream = (!query.stream)? "livestream":query.stream;
- var api = query.api? ':'+query.api : '';
- var queries = [];
- if (server !== vhost && vhost !== "__defaultVhost__") {
- queries.push("vhost=" + vhost);
- }
- if (query.schema && window.location.protocol !== query.schema + ':') {
- queries.push('schema=' + query.schema);
- }
- queries = user_extra_params(query, queries);
- var uri = "webrtc://" + server + api + "/" + app + "/" + stream + "?" + queries.join('&');
- while (uri.lastIndexOf("?") === uri.length - 1) {
- uri = uri.substr(0, uri.length - 1);
- }
- return uri;
- };
- /**
- * initialize the page.
- * @param flv_url the div id contains the flv stream url to play
- * @param hls_url the div id contains the hls stream url to play
- * @param modal_player the div id contains the modal player
- */
- function srs_init_flv(flv_url, modal_player) {
- update_nav();
- if (flv_url) {
- $(flv_url).val(build_default_flv_url());
- }
- if (modal_player) {
- $(modal_player).width(srs_get_player_modal() + "px");
- $(modal_player).css("margin-left", "-" + srs_get_player_modal() / 2 +"px");
- }
- }
- function srs_init_rtc(id, query) {
- update_nav();
- $(id).val(build_default_rtc_url(query));
- }
- // for bw to init url
- // url: scheme://host:port/path?query#fragment
- function srs_init_bwt(rtmp_url, hls_url) {
- update_nav();
-
- if (rtmp_url) {
- $(rtmp_url).val(build_default_bandwidth_rtmp_url());
- }
- }
- // check whether can republish
- function srs_can_republish() {
- var browser = get_browser_agents();
-
- if (browser.Chrome || browser.Firefox) {
- return true;
- }
-
- if (browser.MSIE || browser.QQBrowser) {
- return false;
- }
-
- return false;
- }
- // without default values set.
- function srs_initialize_codec_page(
- cameras, microphones,
- sl_cameras, sl_microphones, sl_vcodec, sl_profile, sl_level, sl_gop, sl_size, sl_fps, sl_bitrate,
- sl_acodec
- ) {
- $(sl_cameras).empty();
- for (var i = 0; i < cameras.length; i++) {
- $(sl_cameras).append("<option value='" + i + "'>" + cameras[i] + "</option");
- }
- // optional: select the except matches
- matchs = ["virtual"];
- for (var i = 0; i < cameras.length; i++) {
- for (var j = 0; j < matchs.length; j++) {
- if (cameras[i].toLowerCase().indexOf(matchs[j]) == -1) {
- $(sl_cameras + " option[value='" + i + "']").attr("selected", true);
- break;
- }
- }
- if (j < matchs.length) {
- break;
- }
- }
- // optional: select the first matched.
- matchs = ["truevision", "integrated"];
- for (var i = 0; i < cameras.length; i++) {
- for (var j = 0; j < matchs.length; j++) {
- if (cameras[i].toLowerCase().indexOf(matchs[j]) >= 0) {
- $(sl_cameras + " option[value='" + i + "']").attr("selected", true);
- break;
- }
- }
- if (j < matchs.length) {
- break;
- }
- }
-
- $(sl_microphones).empty();
- for (var i = 0; i < microphones.length; i++) {
- $(sl_microphones).append("<option value='" + i + "'>" + microphones[i] + "</option");
- }
- // optional: select the except matches
- matchs = ["default"];
- for (var i = 0; i < microphones.length; i++) {
- for (var j = 0; j < matchs.length; j++) {
- if (microphones[i].toLowerCase().indexOf(matchs[j]) == -1) {
- $(sl_microphones + " option[value='" + i + "']").attr("selected", true);
- break;
- }
- }
- if (j < matchs.length) {
- break;
- }
- }
- // optional: select the first matched.
- matchs = ["realtek", "内置式麦克风"];
- for (var i = 0; i < microphones.length; i++) {
- for (var j = 0; j < matchs.length; j++) {
- if (microphones[i].toLowerCase().indexOf(matchs[j]) >= 0) {
- $(sl_microphones + " option[value='" + i + "']").attr("selected", true);
- break;
- }
- }
- if (j < matchs.length) {
- break;
- }
- }
-
- $(sl_vcodec).empty();
- var vcodecs = ["h264", "vp6"];
- vcodecs = ["h264"]; // h264 only.
- for (var i = 0; i < vcodecs.length; i++) {
- $(sl_vcodec).append("<option value='" + vcodecs[i] + "'>" + vcodecs[i] + "</option");
- }
-
- $(sl_profile).empty();
- var profiles = ["baseline", "main"];
- for (var i = 0; i < profiles.length; i++) {
- $(sl_profile).append("<option value='" + profiles[i] + "'>" + profiles[i] + "</option");
- }
-
- $(sl_level).empty();
- var levels = ["1", "1b", "1.1", "1.2", "1.3",
- "2", "2.1", "2.2", "3", "3.1", "3.2", "4", "4.1", "4.2", "5", "5.1"];
- for (var i = 0; i < levels.length; i++) {
- $(sl_level).append("<option value='" + levels[i] + "'>" + levels[i] + "</option");
- }
-
- $(sl_gop).empty();
- var gops = ["0.3", "0.5", "1", "2", "3", "4",
- "5", "6", "7", "8", "9", "10", "15", "20"];
- for (var i = 0; i < gops.length; i++) {
- $(sl_gop).append("<option value='" + gops[i] + "'>" + gops[i] + "秒</option");
- }
-
- $(sl_size).empty();
- var sizes = ["176x144", "320x240", "352x240",
- "352x288", "480x360", "640x480", "720x480", "720x576", "800x600",
- "1024x768", "1280x720", "1360x768", "1920x1080"];
- for (i = 0; i < sizes.length; i++) {
- $(sl_size).append("<option value='" + sizes[i] + "'>" + sizes[i] + "</option");
- }
-
- $(sl_fps).empty();
- var fpses = ["5", "10", "15", "20", "24", "25", "29.97", "30"];
- for (i = 0; i < fpses.length; i++) {
- $(sl_fps).append("<option value='" + fpses[i] + "'>" + Number(fpses[i]).toFixed(2) + " 帧/秒</option");
- }
-
- $(sl_bitrate).empty();
- var bitrates = ["50", "200", "350", "500", "650", "800",
- "950", "1000", "1200", "1500", "1800", "2000", "3000", "5000"];
- for (i = 0; i < bitrates.length; i++) {
- $(sl_bitrate).append("<option value='" + bitrates[i] + "'>" + bitrates[i] + " kbps</option");
- }
-
- $(sl_acodec).empty();
- var bitrates = ["speex", "nellymoser", "pcma", "pcmu"];
- for (i = 0; i < bitrates.length; i++) {
- $(sl_acodec).append("<option value='" + bitrates[i] + "'>" + bitrates[i] + "</option");
- }
- }
- /**
- * when publisher ready, init the page elements.
- */
- function srs_publisher_initialize_page(
- cameras, microphones,
- sl_cameras, sl_microphones, sl_vcodec, sl_profile, sl_level, sl_gop, sl_size, sl_fps, sl_bitrate,
- sl_acodec
- ) {
- srs_initialize_codec_page(
- cameras, microphones,
- sl_cameras, sl_microphones, sl_vcodec, sl_profile, sl_level, sl_gop, sl_size, sl_fps, sl_bitrate,
- sl_acodec
- );
-
- //var profiles = ["baseline", "main"];
- $(sl_profile + " option[value='main']").attr("selected", true);
-
- //var levels = ["1", "1b", "1.1", "1.2", "1.3",
- // "2", "2.1", "2.2", "3", "3.1", "3.2", "4", "4.1", "4.2", "5", "5.1"];
- $(sl_level + " option[value='4.1']").attr("selected", true);
-
- //var gops = ["0.3", "0.5", "1", "2", "3", "4",
- // "5", "6", "7", "8", "9", "10", "15", "20"];
- $(sl_gop + " option[value='10']").attr("selected", true);
-
- //var sizes = ["176x144", "320x240", "352x240",
- // "352x288", "480x360", "640x480", "720x480", "720x576", "800x600",
- // "1024x768", "1280x720", "1360x768", "1920x1080"];
- $(sl_size + " option[value='640x480']").attr("selected", true);
-
- //var fpses = ["5", "10", "15", "20", "24", "25", "29.97", "30"];
- $(sl_fps + " option[value='20']").attr("selected", true);
-
- //var bitrates = ["50", "200", "350", "500", "650", "800",
- // "950", "1000", "1200", "1500", "1800", "2000", "3000", "5000"];
- $(sl_bitrate + " option[value='500']").attr("selected", true);
-
- // speex
- $(sl_acodec + " option[value='speex']").attr("selected", true);
- }
- /**
- * for chat, use low latecy settings.
- */
- function srs_chat_initialize_page(
- cameras, microphones,
- sl_cameras, sl_microphones, sl_vcodec, sl_profile, sl_level, sl_gop, sl_size, sl_fps, sl_bitrate,
- sl_acodec
- ) {
- srs_initialize_codec_page(
- cameras, microphones,
- sl_cameras, sl_microphones, sl_vcodec, sl_profile, sl_level, sl_gop, sl_size, sl_fps, sl_bitrate,
- sl_acodec
- );
-
- //var profiles = ["baseline", "main"];
- $(sl_profile + " option[value='baseline']").attr("selected", true);
-
- //var levels = ["1", "1b", "1.1", "1.2", "1.3",
- // "2", "2.1", "2.2", "3", "3.1", "3.2", "4", "4.1", "4.2", "5", "5.1"];
- $(sl_level + " option[value='3.1']").attr("selected", true);
-
- //var gops = ["0.3", "0.5", "1", "2", "3", "4",
- // "5", "6", "7", "8", "9", "10", "15", "20"];
- $(sl_gop + " option[value='2']").attr("selected", true);
-
- //var sizes = ["176x144", "320x240", "352x240",
- // "352x288", "480x360", "640x480", "720x480", "720x576", "800x600",
- // "1024x768", "1280x720", "1360x768", "1920x1080"];
- $(sl_size + " option[value='480x360']").attr("selected", true);
-
- //var fpses = ["5", "10", "15", "20", "24", "25", "29.97", "30"];
- $(sl_fps + " option[value='15']").attr("selected", true);
-
- //var bitrates = ["50", "200", "350", "500", "650", "800",
- // "950", "1000", "1200", "1500", "1800", "2000", "3000", "5000"];
- $(sl_bitrate + " option[value='350']").attr("selected", true);
-
- // speex
- $(sl_acodec + " option[value='speex']").attr("selected", true);
- }
- /**
- * get the vcodec and acodec.
- */
- function srs_publiser_get_codec(
- vcodec, acodec,
- sl_cameras, sl_microphones, sl_vcodec, sl_profile, sl_level, sl_gop, sl_size, sl_fps, sl_bitrate,
- sl_acodec
- ) {
- acodec.codec = $(sl_acodec).val();
- acodec.device_code = $(sl_microphones).val();
- acodec.device_name = $(sl_microphones).text();
-
- vcodec.device_code = $(sl_cameras).find("option:selected").val();
- vcodec.device_name = $(sl_cameras).find("option:selected").text();
-
- vcodec.codec = $(sl_vcodec).find("option:selected").val();
- vcodec.profile = $(sl_profile).find("option:selected").val();
- vcodec.level = $(sl_level).find("option:selected").val();
- vcodec.fps = $(sl_fps).find("option:selected").val();
- vcodec.gop = $(sl_gop).find("option:selected").val();
- vcodec.size = $(sl_size).find("option:selected").val();
- vcodec.bitrate = $(sl_bitrate).find("option:selected").val();
- }
|