正在显示
3 个修改的文件
包含
6 行增加
和
197 行删除
1 | -.wizard { | ||
2 | - display:none; | ||
3 | -} | ||
4 | -.wizard-modal form { | ||
5 | - margin:0; | ||
6 | - padding:0; | ||
7 | -} | ||
8 | -.wizard-modal.modal { | ||
9 | - width:750px; | ||
10 | - margin-left:-375px; | ||
11 | - top:50%; | ||
12 | -} | ||
13 | -.wizard-modal-footer { | ||
14 | - padding:0; | ||
15 | -} | ||
16 | -.wizard-modal-header.modal-header h3 { | ||
17 | - line-height:35px; | ||
18 | - display:inline | ||
19 | -} | ||
20 | -.wizard-modal-header.modal-header { | ||
21 | - border-bottom:0; | ||
22 | -} | ||
23 | - | ||
24 | -.wizard-subtitle { | ||
25 | - font-weight:bold; | ||
26 | - color:#AFAFAF; | ||
27 | - padding-left:20px; | ||
28 | -} | ||
29 | - | ||
30 | -.wizard-error, | ||
31 | -.wizard-failure, | ||
32 | -.wizard-success, | ||
33 | -.wizard-loading, | ||
34 | -.wizard-card { | ||
35 | - position:relative; | ||
36 | - padding:35px; | ||
37 | - padding-top:20px; | ||
38 | - overflow-y:auto; | ||
39 | - height:300px; | ||
40 | - display:none; | ||
41 | - border-top: 1px solid #EEE; | ||
42 | - margin-right: 5px; | ||
43 | -} | ||
44 | - | ||
45 | -.wizard-nav-link .icon-chevron-right { | ||
46 | - float:right; | ||
47 | - margin-top:12px; | ||
48 | - margin-right:-6px; | ||
49 | - opacity:.25; | ||
50 | -} | ||
51 | - | ||
52 | -li.wizard-nav-item.active .icon-chevron-right { | ||
53 | - opacity:1; | ||
54 | -} | ||
55 | - | ||
56 | -li.wizard-nav-item { | ||
57 | - line-height:40px; | ||
58 | -} | ||
59 | - | ||
60 | -.wizard-no-modal .nav-list > li > a, | ||
61 | -.wizard-modal.modal .nav-list > li > a { | ||
62 | - background-color:#f5f5f5; | ||
63 | - padding:3px 15px 3px 20px; | ||
64 | - cursor:default; | ||
65 | - color:#B4B4B4; | ||
66 | -} | ||
67 | - | ||
68 | -.wizard-no-modal .nav-list li.active > a, | ||
69 | -.wizard-modal.modal .nav-list li.active > a { | ||
70 | - background-color:#08C; | ||
71 | -} | ||
72 | -.wizard-no-modal .nav-list > li.already-visited > a.wizard-nav-link, | ||
73 | -.wizard-modal.modal .nav-list > li.already-visited > a.wizard-nav-link { | ||
74 | - color:#08C; | ||
75 | - cursor:pointer; | ||
76 | -} | ||
77 | - | ||
78 | -.wizard-no-modal .nav-list > li.active > a.wizard-nav-link, | ||
79 | -.wizard-modal.modal .nav-list > li.active > a.wizard-nav-link { | ||
80 | - color:white; | ||
81 | -} | ||
82 | - | ||
83 | -.already-visited > a.wizard-nav-link:hover { | ||
84 | - background-color:#E4E4E4; | ||
85 | -} | ||
86 | - | ||
87 | -.wizard-card > h3 { | ||
88 | - margin-top:0; | ||
89 | - margin-bottom:20px; | ||
90 | - font-size:21px; | ||
91 | - line-height:40px; | ||
92 | - font-weight:normal; | ||
93 | -} | ||
94 | - | ||
95 | -.wizard-progress { | ||
96 | - padding:15px; | ||
97 | - bottom:0; | ||
98 | -} | ||
99 | -.wizard-progress-container { | ||
100 | - padding:20px; | ||
101 | -} | ||
102 | - | ||
103 | -.wizard-steps { | ||
104 | - width:28%; | ||
105 | - height:425px; | ||
106 | - background-color:#f5f5f5; | ||
107 | -} | ||
108 | - | ||
109 | -.wizard-nav-container { | ||
110 | - height:360px; | ||
111 | -} | ||
112 | - | ||
113 | -.nav > li > a.wizard-step-error { | ||
114 | - background-color:#F2DEDE; | ||
115 | - color:#B94A48; | ||
116 | - font-weight:bold; | ||
117 | -} | ||
118 | - | ||
119 | -.wizard-step-error .icon-chevron-right { | ||
120 | - opacity:0; | ||
121 | -} | ||
122 | - | ||
123 | -.wizard-input-section { | ||
124 | - margin-bottom:20px; | ||
125 | -} | ||
126 | - | ||
127 | -.wizard-buttons-container { | ||
128 | - padding:20px; | ||
129 | -} | ||
130 | - | ||
131 | -.wizard-cancel { | ||
132 | - display:none; | ||
133 | - margin-left:20px; | ||
134 | -} | ||
135 | - | ||
136 | -.wizard-close { | ||
137 | - display: none; | ||
138 | -} | ||
139 | - | ||
140 | -.wizard-no-modal .popover.error-popover, | ||
141 | -.wizard-modal .popover.error-popover { | ||
142 | - background-color:#F2DEDE; | ||
143 | - color:#B94A48; | ||
144 | - border-color:#953B39; | ||
145 | -} | ||
146 | - | ||
147 | -.wizard-no-modal .popover.error-popover .arrow::after, | ||
148 | -.wizard-modal .popover.error-popover .arrow::after { | ||
149 | - border-right-color:#F2DEDE; | ||
150 | -} | ||
151 | - | ||
152 | -.wizard-no-modal .popover.error-popover .popover-title, | ||
153 | -.wizard-modal .popover.error-popover .popover-title { | ||
154 | - display:none; | ||
155 | -} | ||
156 | - | ||
157 | -.wizard-no-modal .popover.error-popover .arrow, | ||
158 | -.wizard-modal .popover.error-popover .arrow { | ||
159 | - border-right-color:#953B39; | ||
160 | -} |
1 | -!function(a){a.fn.wizard=function(a){return new Wizard(this,a)},a.fn.wizard.logging=!1;var b=function(a,b,c,d,e){this.wizard=a,this.index=c,this.prev=d,this.next=e,this.el=b,this.title=b.find("h3").first().text(),this.name=b.data("cardname")||this.title,this.nav=this._createNavElement(this.title,c),this._disabled=!1,this._loaded=!1,this._events={}};b.prototype={select:function(){this.log("selecting"),this.isSelected()||(this.nav.addClass("active"),this.el.show(),this._loaded||(this.trigger("loaded"),this.reload()),this.trigger("selected"));var a=this.wizard;return a.backButton.toggleClass("disabled",0==this.index),this.index>=a._cards.length-1?(this.log("on last card, changing next button to submit"),a.changeNextButton(a.args.buttons.submitText,"btn-success"),a._readyToSubmit=!0,a.trigger("readySubmit")):(a._readyToSubmit=!1,a.changeNextButton(a.args.buttons.nextText,"btn-primary")),this},_createNavElement:function(b,c){var d=a('<li class="wizard-nav-item"></li>'),e=a('<a class="wizard-nav-link"></a>');return e.data("navindex",c),d.append(e),e.append('<i class="icon-chevron-right"></i>'),e.append(b),d},markVisited:function(){return this.log("marking as visited"),this.nav.addClass("already-visited"),this.trigger("markVisited"),this},unmarkVisited:function(){return this.log("unmarking as visited"),this.nav.removeClass("already-visited"),this.trigger("unmarkVisited"),this},deselect:function(){return this.nav.removeClass("active"),this.el.hide(),this.trigger("deselect"),this},enable:function(){return this.log("enabling"),this.nav.addClass("active"),this._disabled=!1,this.trigger("enabled"),this},disable:function(a){return this.log("disabling"),this._disabled=!0,this.nav.removeClass("active already-visited"),a&&this.el.hide(),this.trigger("disabled"),this},isDisabled:function(){return this._disabled},alreadyVisited:function(){return this.nav.hasClass("already-visited")},isSelected:function(){return this.nav.hasClass("active")},reload:function(){return this._loaded=!0,this.trigger("reload"),this},on:function(){return this.wizard.on.apply(this,arguments)},trigger:function(){return this.callListener("on"+arguments[0]),this.wizard.trigger.apply(this,arguments)},toggleAlert:function(b,c){this.log("toggling alert to: "+c),c="undefined"==typeof c?!0:c,c?this.trigger("showAlert"):this.trigger("hideAlert");var d,e=this.el.children("h3").first().next("div.alert");if(0==e.length){if(!c)return this;this.log("couldn't find existing alert div, creating one"),d=a("<div />"),d.addClass("alert"),d.addClass("hide"),d.insertAfter(this.el.find("h3").first())}else this.log("found existing alert div"),d=e.first();return c?(null!=b&&(this.log("setting alert msg to",b),d.html(b)),d.show()):d.hide(),this},callListener:function(a){a=a.toLowerCase(),this.log("looking for listener "+a);var b=window[this.el.data(a)];if(b){this.log("calling listener "+a),this.wizard;try{b(this)}catch(e){this.log("exception calling listener "+a+": ",e)}}else this.log("didn't find listener "+a)},problem:function(a){this.nav.find("a").toggleClass("wizard-step-error",a)},validate:function(){var b=!1,c=this;this.el.find("[data-validate]").each(function(d,e){c.log("validating individiual inputs"),e=a(e);var f=e.data("validate");if(f){var g={status:!0,title:"Error",msg:""},h=window[f](e);if(a.extend(g,h),g.status){e.parent(".control-group").toggleClass("error",!1);try{e.popover("destroy")}catch(i){e.popover("hide")}}else b=!0,e.parent(".control-group").toggleClass("error",!0),c.wizard.errorPopover(e,g.msg)}}),this.log("after validating inputs, failures is",b);var d=window[this.el.data("validate")];if(d){this.log("running html-embedded card validator");var e=d(this);("undefined"==typeof e||null==e)&&(e=!0),e||(b=!0),this.log("after running html-embedded card validator, failures is",b)}this.log("running listener validator");var f=this.trigger("validate");("undefined"==typeof f||null==f)&&(f=!0),f||(b=!0),this.log("after running listener validator, failures is",b);var g=!b;return g?(this.log("validated, calling listeners"),this.trigger("validated")):(this.log("invalid"),this.trigger("invalid")),g},log:function(){if(window.console&&a.fn.wizard.logging){var b="card '"+this.name+"': ",c=[b];c.push.apply(c,arguments),console.log.apply(console,c)}},isActive:function(){return this.nav.hasClass("active")}},Wizard=function(b,c){var d=['<div class="modal hide wizard-modal" role="dialog">','<div class="wizard-modal-header modal-header">','<button class="wizard-close close" type="button">x</button>','<h3 class="wizard-title"></h3>','<span class="wizard-subtitle"></span>',"</div>",'<div class="pull-left wizard-steps">','<div class="wizard-nav-container">','<ul class="nav nav-list" style="padding-bottom:30px;">',"</ul>","</div>",'<div class="wizard-progress-container">',,'<div class="progress progress-striped">','<div class="bar"></div>',"</div>","</div>","</div>","<form>",'<div class="wizard-cards">','<div class="wizard-card-container">',"</div>",'<div class="wizard-modal-footer">','<div class="wizard-buttons-container">','<button class="btn wizard-cancel wizard-close" type="button">Cancel</button>','<div class="btn-group-single pull-right">','<button class="btn wizard-back" type="button">Back</button>','<button class="btn btn-primary wizard-next" type="button">Next</button>',"</div>","</div>","</div>","</div>","</form>","</div>"],e=['<div class="wizard-no-modal" role="dialog">','<div class="wizard-modal-header modal-header">','<button class="wizard-close close" type="button">x</button>','<h3 class="wizard-title"></h3>','<span class="wizard-subtitle"></span>',"</div>",'<div class="pull-left wizard-steps">','<div class="wizard-nav-container">','<ul class="nav nav-list" style="padding-bottom:30px;">',"</ul>","</div>",'<div class="wizard-progress-container">',,'<div class="progress progress-striped">','<div class="bar"></div>',"</div>","</div>","</div>","<form>",'<div class="wizard-cards">','<div class="wizard-card-container">',"</div>",'<div class="wizard-modal-footer">','<div class="wizard-buttons-container">','<button class="btn wizard-cancel wizard-close" type="button">Cancel</button>','<div class="btn-group-single pull-right">','<button class="btn wizard-back" type="button">Back</button>','<button class="btn btn-primary wizard-next" type="button">Next</button>',"</div>","</div>","</div>","</div>","</form>","</div>"];this.args={submitUrl:"",width:750,showCancel:!1,showClose:!0,progressBarCurrent:!1,increaseHeight:0,buttons:{cancelText:"Cancel",nextText:"Next",backText:"Back",submitText:"Submit",submittingText:"Submitting..."},isModal:!0},a.extend(this.args,c||{});var f=this.args.isModal?d:e;this.args.isModal||(this.args.showCancel=!1,this.args.showClose=!1),this.markup=a(b),this.submitCards=this.markup.find(".wizard-error,.wizard-failure,.wizard-success,.wizard-loading"),this.el=a(f.join("\n")),this.el.find(".wizard-card-container").append(this.markup.find(".wizard-card")).append(this.submitCards),a("body").append(this.el),this.closeButton=this.el.find("button.wizard-close"),this.footer=this.el.find(".wizard-modal-footer"),this.cancelButton=this.footer.find(".wizard-cancel"),this.backButton=this.footer.find(".wizard-back"),this.nextButton=this.footer.find(".wizard-next"),this.progress=this.el.find(".progress"),this._cards=[],this.cards={},this._readyToSubmit=!1,this.percentComplete=0,this._submitting=!1,this._events={},this._firstShow=!0,this._createCards(),this.nextButton.click(this,this._handleNextClick),this.backButton.click(this,this._handleBackClick),this.cancelButton.text(this.args.buttons.cancelText),this.backButton.text(this.args.buttons.backText),this.nextButton.text(this.args.buttons.nextText);var g=360,h=g+this.args.increaseHeight;this.el.find(".wizard-nav-container").css("height",h),this.el.find(".wizard-steps").css("height",h+65+"px"),this.el.find(".wizard-card").css("height",h-60+"px"),this.submitCards.css("height",h-60+"px"),this.args.isModal&&this.el.css("margin-top",-(this.el.height()/2)),this.el.css("width",this.args.width),this.args.isModal&&this.el.css("margin-left",-(this.args.width/2));var j=this;this.closeButton.click(function(){j.reset(),j.close(),j.trigger("closed")}),this.el.find(".wizard-steps").on("click","li.already-visited a.wizard-nav-link",this,function(b){var c=parseInt(a(b.target).data("navindex"));b.data.setCard(c)});var k=this.markup.children("h1").first();k.length&&this.setTitle(k.text()),this.on("submit",this._defaultSubmit)},Wizard.prototype={errorPopover:function(a,b){this.log("launching popover on",a);var c=a.popover({content:b,trigger:"manual"}).popover("show").next(".popover");return c.addClass("error-popover"),c},destroyPopover:function(b){b=a(b),b.parent(".control-group").toggleClass("error",!1);var c=b.prev();try{c.popover("destroy")}catch(d){c.popover("hide")}},hidePopovers:function(){this.log("hiding all popovers");var b=this;this.el.find(".error-popover").each(function(a,c){b.destroyPopover(c)})},eachCard:function(b){return a.each(this._cards,b),this},getActiveCard:function(){this.log("getting active card");var b=null;return a.each(this._cards,function(a,c){return c.isActive()?(b=c,!1):void 0}),b?this.log("found active card",b):this.log("couldn't find an active card"),b},setTitle:function(a){return this.log("setting title to",a),this.el.find(".wizard-title").first().text(a),this},setSubtitle:function(a){return this.log("setting subtitle to",a),this.el.find(".wizard-subtitle").first().text(a),this},changeNextButton:function(a,b){return this.log("changing next button, text: "+a,"class: "+b),"undefined"!=typeof b&&this.nextButton.removeClass("btn-success btn-primary"),b&&this.nextButton.addClass(b),this.nextButton.text(a),this},hide:function(){return this.log("hiding"),this.args.isModal?this.el.modal("hide"):this.el.css("display","none"),this},close:function(){return this.log("closing"),this.args.isModal?this.el.modal("hide"):this.el.css("display","none"),this},show:function(a){return this.log("showing"),this._firstShow&&(this.setCard(0),this._firstShow=!1),this.args.showCancel&&this.cancelButton.show(),this.args.showClose&&this.closeButton.show(),this.args.isModal?this.el.modal(a):this.el.css("display","block"),this},on:function(a,b){return this.log("adding listener to event "+a),this._events[a]=b,this},trigger:function(){var a=arguments[0],b=Array.prototype.slice.call(arguments);b.shift(),b.unshift(this),this.log("firing event "+a);var c=this._events[a],d=null;if("function"==typeof c){this.log("found event handler, calling "+a);try{d=c.apply(this,b)}catch(e){this.log("event handler "+a+" had an exception")}}else this.log("couldn't find an event handler for "+a);return d},reset:function(){return this.log("resetting"),this.updateProgressBar(0),this.hideSubmitCards(),this.setCard(0),this.lockCards(),this.enableNextButton(),this.showButtons(),this.hidePopovers(),this.trigger("reset"),this},log:function(){if(window.console&&a.fn.wizard.logging){var b="wizard "+this.el.id+": ",c=[b];c.push.apply(c,arguments),console.log.apply(console,c)}},_abstractIncrementStep:function(a,b){var d,c=this.getActiveCard();if(c)for(this.log("searching for valid next card");;){if(d=b(c)){if(this.log("looking at card",d.index),d.isDisabled()){this.log("card "+d.index+" is disabled/locked, continuing"),c=d;continue}return this.setCard(c.index+a)}this.log("next card is not defined, breaking");break}else this.log("current card is undefined")},incrementCard:function(){this.log("incrementing card");var a=this._abstractIncrementStep(1,function(a){return a.next});return this.trigger("incrementCard"),a},decrementCard:function(){this.log("decrementing card");var a=this._abstractIncrementStep(-1,function(a){return a.prev});return this.trigger("decrementCard"),a},setCard:function(a){this.log("setting card to "+a),this.hideSubmitCards();var b=this.getActiveCard();if(this._submitting)return this.log("we're submitting the wizard already, can't change cards"),b;var c=this._cards[a];if(c){if(c.isDisabled())return this.log("new card is currently disabled, returning"),b;if(b){if(a>b.index){for(var d=b,e=!1;d.index!=c.index;){if(d.index!=b.index&&(d.prev.deselect(),d.prev.markVisited(),d.select()),e=d.validate(),!e)return d;d=d.next}d.prev.deselect(),d.prev.markVisited()}b.deselect(),b.markVisited()}if(c.select(),this.args.progressBarCurrent)this.percentComplete=100*a/this._cards.length,this.updateProgressBar(this.percentComplete);else{var f=this.percentComplete;this.percentComplete=100*a/this._cards.length,this.percentComplete=Math.max(f,this.percentComplete),this.updateProgressBar(this.percentComplete)}return c}this.log("couldn't find card "+a)},updateProgressBar:function(a){this.log("updating progress to "+a+"%"),this.progress.find(".bar").css({width:a+"%"}),this.percentComplete=a,this.trigger("progressBar",a),100==a?(this.log("progress is 100, animating progress bar"),this.progress.addClass("active")):0==a&&(this.log("progress is 0, disabling animation"),this.progress.removeClass("active"))},getNextCard:function(){var a=this.getActiveCard();return a?a.next:void 0},lockCards:function(){return this.log("locking nav cards"),this.eachCard(function(a,b){b.unmarkVisited()}),this},disableCards:function(){return this.log("disabling all nav cards"),this.eachCard(function(a,b){b.disable()}),this},enableCards:function(){return this.log("enabling all nav cards"),this.eachCard(function(a,b){b.enable()}),this},hideCards:function(){return this.log("hiding cards"),this.eachCard(function(a,b){b.deselect()}),this.hideSubmitCards(),this},hideButtons:function(){return this.log("hiding buttons"),this.cancelButton.hide(),this.closeButton.hide(),this.nextButton.hide(),this.backButton.hide(),this},showButtons:function(){return this.log("showing buttons"),this.args.showCancel&&this.cancelButton.show(),this.args.showClose&&this.closeButton.show(),this.nextButton.show(),this.backButton.show(),this},getCard:function(b){var c=a(b).parents(".wizard-card").first()[0];if(c){var d=null;return this.eachCard(function(a,b){return c==b.el[0]?(d=b,!1):!0}),d}return null},_createCards:function(){var c=null,d=null,e=null,f=this,g=this,h=this.el.find(".wizard-cards .wizard-card");a.each(h,function(h,i){i=a(i),c=e,e=new b(f,i,h,c,d),g._cards.push(e),e.name&&(g.cards[e.name]=e),c&&(c.next=e),g.el.find(".wizard-steps .nav-list").append(e.nav)})},showSubmitCard:function(a){this.log("showing "+a+" submit card");var b=this.el.find(".wizard-"+a);b.length?(this.hideCards(),this.el.find(".wizard-"+a).show()):this.log("couldn't find submit card "+a)},hideSubmitCard:function(a){this.log("hiding "+a+" submit card"),this.el.find(".wizard-"+a).hide()},hideSubmitCards:function(){var b=this;a.each(["success","error","failure","loading"],function(a,c){b.hideSubmitCard(c)})},enableNextButton:function(){return this.log("enabling next button"),this.nextButton.removeAttr("disabled"),this},disableNextButton:function(){return this.log("disabling next button"),this.nextButton.attr("disabled","disabled"),this},serializeArray:function(){var a=this.el.children("form").first();return a.serializeArray()},serialize:function(){var a=this.el.children("form").first();return a.serialize()},submitSuccess:function(){this.log("submit success"),this._submitting=!1,this.showSubmitCard("success"),this.trigger("submitSuccess")},submitFailure:function(){this.log("submit failure"),this._submitting=!1,this.showSubmitCard("failure"),this.trigger("submitFailure")},submitError:function(){this.log("submit error"),this._submitting=!1,this.showSubmitCard("error"),this.trigger("submitError")},_submit:function(){this.log("submitting wizard"),this._submitting=!0,this.lockCards(),this.cancelButton.hide(),this.closeButton.hide(),this.backButton.hide(),this.showSubmitCard("loading"),this.updateProgressBar(100),this.changeNextButton(this.args.buttons.submittingText,!1),this.disableNextButton(),this.trigger("submit"),this.trigger("loading")},_onNextClick:function(){this.log("handling 'next' button click");var a=this.getActiveCard();this._readyToSubmit&&a.validate()?this._submit():a=this.incrementCard()},_onBackClick:function(){this.log("handling 'back' button click"),this.decrementCard()},_handleNextClick:function(a){var b=a.data;b._onNextClick.call(b)},_handleBackClick:function(a){var b=a.data;b._onBackClick.call(b)},_defaultSubmit:function(b){a.ajax({type:"POST",url:b.args.submitUrl,data:b.serialize(),dataType:"json",success:function(){b.submitSuccess(),b.hideButtons(),b.updateProgressBar(0)},error:function(){b.submitFailure(),b.hideButtons()}})}}}(window.jQuery); |
@@ -4,10 +4,8 @@ | @@ -4,10 +4,8 @@ | ||
4 | <title>SRS</title> | 4 | <title>SRS</title> |
5 | <meta charset="utf-8"> | 5 | <meta charset="utf-8"> |
6 | <link rel="stylesheet" type="text/css" href="css/bootstrap.min.css"/> | 6 | <link rel="stylesheet" type="text/css" href="css/bootstrap.min.css"/> |
7 | - <link rel="stylesheet" type="text/css" href="css/bootstrap-wizard.css"/> | ||
8 | <script type="text/javascript" src="js/jquery-1.10.2.min.js"></script> | 7 | <script type="text/javascript" src="js/jquery-1.10.2.min.js"></script> |
9 | <script type="text/javascript" src="js/bootstrap.min.js"></script> | 8 | <script type="text/javascript" src="js/bootstrap.min.js"></script> |
10 | - <script type="text/javascript" src="js/bootstrap-wizard.min.js"></script> | ||
11 | <script type="text/javascript" src="js/swfobject.js"></script> | 9 | <script type="text/javascript" src="js/swfobject.js"></script> |
12 | <script type="text/javascript" src="js/srs.js"></script> | 10 | <script type="text/javascript" src="js/srs.js"></script> |
13 | <style> | 11 | <style> |
@@ -27,20 +25,13 @@ | @@ -27,20 +25,13 @@ | ||
27 | // url set to: rtmp://demo:1935/live/livestream | 25 | // url set to: rtmp://demo:1935/live/livestream |
28 | srs_init("#txt_url", null, null); | 26 | srs_init("#txt_url", null, null); |
29 | 27 | ||
30 | - $("#btn_video_settings").click(function(){ | 28 | + $("#btn_create_chat").click(function(){ |
31 | $("#video_modal").modal({show:true}); | 29 | $("#video_modal").modal({show:true}); |
32 | }); | 30 | }); |
33 | - $("#btn_audio_settings").click(function(){ | 31 | + $("#btn_join_chat").click(function(){ |
34 | $("#audio_modal").modal({show:true}); | 32 | $("#audio_modal").modal({show:true}); |
35 | }); | 33 | }); |
36 | 34 | ||
37 | - $("#remote_tips").tooltip({ | ||
38 | - title: "为了支持HLS输出,FLASH编码器输出的流需要经过转码(VP6=>H264,MP3=>aac),所以会黑屏较长时间,请耐心等待" | ||
39 | - }); | ||
40 | - $("#low_latecy_tips").tooltip({ | ||
41 | - title: "服务器不转码直接转发FLASH编码器的流,所以延迟比支持HLS的流要低很多" | ||
42 | - }); | ||
43 | - | ||
44 | $("#btn_publish").click(on_user_publish); | 35 | $("#btn_publish").click(on_user_publish); |
45 | 36 | ||
46 | // for publish, we use randome stream name. | 37 | // for publish, we use randome stream name. |
@@ -126,7 +117,7 @@ | @@ -126,7 +117,7 @@ | ||
126 | }; | 117 | }; |
127 | srs_publisher.start(); | 118 | srs_publisher.start(); |
128 | 119 | ||
129 | - //wizard = $("#main_wizard").wizard({}); | 120 | + //wizard = $("#some-wizard").wizard({}); |
130 | //wizard.show(); | 121 | //wizard.show(); |
131 | 122 | ||
132 | // if no play specified, donot show the player, for debug the publisher. | 123 | // if no play specified, donot show the player, for debug the publisher. |
@@ -150,14 +141,6 @@ | @@ -150,14 +141,6 @@ | ||
150 | } | 141 | } |
151 | }); | 142 | }); |
152 | 143 | ||
153 | - /** | ||
154 | - * we generate the transcoded stream url for flash publish donot support HLS | ||
155 | - * which requires aac, so the publish vhost maybe players for example, we | ||
156 | - * use players_pub vhost(transcoded stream to which) for all clients, | ||
157 | - * both players and players_pub are write HLS to the sample dir, | ||
158 | - * it's ok for the players vhost disabled the HLS, only the | ||
159 | - * players_pub enalbed HLS. | ||
160 | - */ | ||
161 | function update_play_url() { | 144 | function update_play_url() { |
162 | var url = $("#txt_url").val(); | 145 | var url = $("#txt_url").val(); |
163 | var ret = srs_parse_rtmp_url(url); | 146 | var ret = srs_parse_rtmp_url(url); |
@@ -277,25 +260,12 @@ | @@ -277,25 +260,12 @@ | ||
277 | <div class="alert alert-info fade in" id="txt_log"> | 260 | <div class="alert alert-info fade in" id="txt_log"> |
278 | <button type="button" class="close" data-dismiss="alert">×</button> | 261 | <button type="button" class="close" data-dismiss="alert">×</button> |
279 | <strong><span id="txt_log_title">Usage:</span></strong> | 262 | <strong><span id="txt_log_title">Usage:</span></strong> |
280 | - <span id="txt_log_msg">设置编码参数,点“发布视频”,允许Flash访问摄像头即可推流</span> | ||
281 | - </div> | ||
282 | - <!-- http://www.panopta.com/2013/02/06/bootstrap-application-wizard/ --> | ||
283 | - <!-- https://github.com/amoffat/bootstrap-application-wizard --> | ||
284 | -<div class="wizard" id="main_wizard" data-title="Wizard Title"> | ||
285 | - <div class="wizard-card" data-cardname="card1"> | ||
286 | - <h3>Card 1</h3> | ||
287 | - Some content | 263 | + <span id="txt_log_msg">创建会议室,或者加入会议室</span> |
288 | </div> | 264 | </div> |
289 | - | ||
290 | - <div class="wizard-card" data-cardname="card2"> | ||
291 | - <h3>Card 2</h3> | ||
292 | - Some content | ||
293 | - </div> | ||
294 | -</div> | ||
295 | <div class="control-group"> | 265 | <div class="control-group"> |
296 | <div class="form-inline"> | 266 | <div class="form-inline"> |
297 | - <button class="btn" id="btn_video_settings">视频编码配置</button> | ||
298 | - <button class="btn" id="btn_audio_settings">音频编码配置</button> | 267 | + <button class="btn" id="btn_create_chat">创建会议室</button> |
268 | + <button class="btn" id="btn_join_chat">加入会议室</button> | ||
299 | </div> | 269 | </div> |
300 | </div> | 270 | </div> |
301 | <div class="control-group"> | 271 | <div class="control-group"> |
-
请 注册 或 登录 后发表评论