rtcpushapi-asr.html 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8"/>
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6. <title>WebRTC webcam</title>
  7. <style>
  8. button {
  9. padding: 8px 16px;
  10. }
  11. video {
  12. width: 100%;
  13. }
  14. .option {
  15. margin-bottom: 8px;
  16. }
  17. #media {
  18. max-width: 1280px;
  19. }
  20. </style>
  21. </head>
  22. <body>
  23. <div class="option">
  24. <input id="use-stun" type="checkbox"/>
  25. <label for="use-stun">Use STUN server</label>
  26. </div>
  27. <button class="btn btn-primary" id="btn_play">Start</button>
  28. <input type="hidden" id="sessionid" value="0">
  29. <form class="form-inline" id="echo-form">
  30. <div class="form-group">
  31. <p>input text</p>
  32. <textarea cols="2" rows="3" style="width:600px;height:50px;" class="form-control" id="message">test</textarea>
  33. </div>
  34. <button type="submit" class="btn btn-default">Send</button>
  35. </form>
  36. <div id="media">
  37. <h2>Media</h2>
  38. <video id="rtc_media_player" style="width:600px;" controls autoplay></video>
  39. </div>
  40. <iframe src="asr/index.html" width="600" height="500"></iframe>
  41. <script src="srs.sdk.js"></script>
  42. <script type="text/javascript" src="http://cdn.sockjs.org/sockjs-0.3.4.js"></script>
  43. <script type="text/javascript" src="https://code.jquery.com/jquery-2.1.1.min.js"></script>
  44. </body>
  45. <script type="text/javascript" charset="utf-8">
  46. $(document).ready(function() {
  47. // var host = window.location.hostname
  48. // var ws = new WebSocket("ws://"+host+":8000/humanecho");
  49. // //document.getElementsByTagName("video")[0].setAttribute("src", aa["video"]);
  50. // ws.onopen = function() {
  51. // console.log('Connected');
  52. // };
  53. // ws.onmessage = function(e) {
  54. // console.log('Received: ' + e.data);
  55. // data = e
  56. // var vid = JSON.parse(data.data);
  57. // console.log(typeof(vid),vid)
  58. // //document.getElementsByTagName("video")[0].setAttribute("src", vid["video"]);
  59. // };
  60. // ws.onclose = function(e) {
  61. // console.log('Closed');
  62. // };
  63. $('#echo-form').on('submit', function(e) {
  64. e.preventDefault();
  65. var message = $('#message').val();
  66. console.log('Sending: ' + message);
  67. fetch('/human', {
  68. body: JSON.stringify({
  69. text: message,
  70. type: 'echo',
  71. }),
  72. headers: {
  73. 'Content-Type': 'application/json'
  74. },
  75. method: 'POST'
  76. });
  77. //ws.send(message);
  78. $('#message').val('');
  79. });
  80. });
  81. $(function(){
  82. var sdk = null; // Global handler to do cleanup when republishing.
  83. var startPlay = function() {
  84. $('#rtc_media_player').show();
  85. // Close PC when user replay.
  86. if (sdk) {
  87. sdk.close();
  88. }
  89. sdk = new SrsRtcWhipWhepAsync();
  90. // User should set the stream when publish is done, @see https://webrtc.org/getting-started/media-devices
  91. // However SRS SDK provides a consist API like https://webrtc.org/getting-started/remote-streams
  92. $('#rtc_media_player').prop('srcObject', sdk.stream);
  93. // Optional callback, SDK will add track to stream.
  94. // sdk.ontrack = function (event) { console.log('Got track', event); sdk.stream.addTrack(event.track); };
  95. var host = window.location.hostname
  96. // For example: webrtc://r.ossrs.net/live/livestream
  97. var url = "http://"+host+":1985/rtc/v1/whep/?app=live&stream=livestream"
  98. sdk.play(url).then(function(session){
  99. //$('#sessionid').html(session.sessionid);
  100. //$('#simulator-drop').attr('href', session.simulator + '?drop=1&username=' + session.sessionid);
  101. }).catch(function (reason) {
  102. sdk.close();
  103. $('#rtc_media_player').hide();
  104. console.error(reason);
  105. });
  106. };
  107. $('#rtc_media_player').hide();
  108. // var query = parse_query_string();
  109. // srs_init_whep("#txt_url", query);
  110. $("#btn_play").click(startPlay);
  111. // Never play util windows loaded @see https://github.com/ossrs/srs/issues/2732
  112. // if (query.autostart === 'true') {
  113. // $('#rtc_media_player').prop('muted', true);
  114. // console.warn('For autostart, we should mute it, see https://www.jianshu.com/p/c3c6944eed5a ' +
  115. // 'or https://developers.google.com/web/updates/2017/09/autoplay-policy-changes#audiovideo_elements');
  116. // window.addEventListener("load", function(){ startPlay(); });
  117. // }
  118. });
  119. </script>
  120. </html>