Recherche avancée

Médias (0)

Mot : - Tags -/serveur

Aucun média correspondant à vos critères n’est disponible sur le site.

Autres articles (111)

  • Submit bugs and patches

    13 avril 2011

    Unfortunately a software is never perfect.
    If you think you have found a bug, report it using our ticket system. Please to help us to fix it by providing the following information : the browser you are using, including the exact version as precise an explanation as possible of the problem if possible, the steps taken resulting in the problem a link to the site / page in question
    If you think you have solved the bug, fill in a ticket and attach to it a corrective patch.
    You may also (...)

  • Publier sur MédiaSpip

    13 juin 2013

    Puis-je poster des contenus à partir d’une tablette Ipad ?
    Oui, si votre Médiaspip installé est à la version 0.2 ou supérieure. Contacter au besoin l’administrateur de votre MédiaSpip pour le savoir

  • HTML5 audio and video support

    13 avril 2011, par

    MediaSPIP uses HTML5 video and audio tags to play multimedia files, taking advantage of the latest W3C innovations supported by modern browsers.
    The MediaSPIP player used has been created specifically for MediaSPIP and can be easily adapted to fit in with a specific theme.
    For older browsers the Flowplayer flash fallback is used.
    MediaSPIP allows for media playback on major mobile platforms with the above (...)

Sur d’autres sites (13909)

  • Not able to configure FFserver for RTSP

    2 novembre 2015, par Sujith

    I am kind of new to the streaming world... so, please forgive me if I ask kind of dumb question.

    I am trying to stream my pre-recorded file over RTSP through FFserver.

    My config file is :

    RTSPPort 8544
    <feed>
       File /home/xyz/tmp/feed2.ffm
       FileMaxSize 200K
       ACL allow 127.0.0.1
    </feed>

    <stream>
       Feed feed2.ffm
       Format rtsp
       VideoFrameRate 15
       VideoSize 352x240
       VideoBitRate 256
       VideoBufferSize 40
       VideoGopSize 30
       AudioBitRate 64
       StartSendOnKey
    </stream>

    After starting the server, it give the below log :

    $ ./ffserver -f doc/ffserver.conf
    ffserver version 0.11.1 Copyright (c) 2000-2012 the FFmpeg developers
    built on Sep 17 2012 19:46:38 with gcc 4.1.2 20080704 (Red Hat 4.1.2-52)
    configuration: --enable-gpl --enable-libmp3lame --enable-libtheora --enable-libvo-aacenc
    -enable-libvorbis --enable-libvpx --enable-libx264 --enable-version3
    libavutil 51. 54.100 / 51. 54.100
    libavcodec 54. 23.100 / 54. 23.100
    libavformat 54. 6.100 / 54. 6.100
    libavdevice 54. 0.100 / 54. 0.100
    libavfilter 2. 77.100 / 2. 77.100
    libswscale 2. 1.100 / 2. 1.100
    libswresample 0. 15.100 / 0. 15.100
    libpostproc 52. 0.100 / 52. 0.100
    Wed Sep 19 17:03:32 2012 FFserver started.

    And now from my VLC client I am trying to type the URL : rtsp ://xxx.xxx.xxx.xxx:8554/test.sdp

    But, what happens is that, there is no response on the ffserver.

    I have no clue what might be the problem. Thanks in advance.

  • OpenCV VideoWriter using ffmpeg with "Could not open codec 'libx264'" Error

    19 avril, par user2262504

    I am new to OpenCV, and I want write Mat images into video using VideoWriter on Ubuntu 12.04. But when constructing VideoWriter, errors came out.

    &#xA;&#xA;

    It seems that OpenCV invoke ffmpeg API using default parameters and ffmpeg invoke x264 using its default parameters. Then these setting is broken for libx264. Thus the "Could not open codec 'libx264'" error.

    &#xA;&#xA;

    Anyone has ideas to solve this problem ?

    &#xA;&#xA;

    More specifically :

    &#xA;&#xA;

      &#xA;
    1. anyone knows where and how OpenCV invoke ffmpeg API ?
    2. &#xA;

    3. how to change ffmpeg default settings using code, hopefull, can be easily embeded into OpenCV ?
    4. &#xA;

    5. will changes of default in ffmpeg be carried to libx264 ?
    6. &#xA;

    &#xA;&#xA;

    Errors :

    &#xA;&#xA;

    1. Uising CV_FOURCC(&#x27;H&#x27;, &#x27;2&#x27;, &#x27;6&#x27;, &#x27;4&#x27;)&#xA;[libx264 @ 0x255de40] broken ffmpeg default settings detected&#xA;[libx264 @ 0x255de40] use an encoding preset (e.g. -vpre medium)&#xA;[libx264 @ 0x255de40] preset usage: -vpre <speed> -vpre <profile>&#xA;[libx264 @ 0x255de40] speed presets are listed in x264 --help&#xA;[libx264 @ 0x255de40] profile is optional; x264 defaults to high&#xA;Could not open codec &#x27;libx264&#x27;: Unspecified error&#xA;&#xA;2. Using FOURCC = -1 to invoke user customized codec&#xA;OpenCV Error: Unsupported format or combination of formats (Gstreamer Opencv &#xA;backend doesn&#x27;t support this codec acutally.) in CvVideoWriter_GStreamer::open, &#xA;file /home/XXX/Downloads/opencv-2.4.8/modules/highgui/src/cap_gstreamer.cpp, &#xA;line 505 terminate called after throwing an instance of &#x27;cv::Exception&#x27;&#xA;what():  /home/XXX/Downloads/opencv-2.4.8/modules/highgui/src/cap_gstreamer.cpp:&#xA;505: error: (-210) Gstreamer Opencv backend doesn&#x27;t support this codec acutally.&#xA;in function CvVideoWriter_GStreamer::open&#xA;</profile></speed>

    &#xA;&#xA;

    Codes :

    &#xA;&#xA;

    int main(int argc, char *argv[])&#xA;{&#xA;    VideoWriter outputVideo;&#xA;    bool fourcc_on = true; //switch on / off different error&#xA;    if (fourcc_on)&#xA;        outputVideo.open("outVideo.avi", CV_FOURCC(&#x27;H&#x27;, &#x27;2&#x27;, &#x27;6&#x27;, &#x27;4&#x27;), 25, Size(100, 100), true);&#xA;    else&#xA;        outputVideo.open("outVideo.avi", -1, 25, Size(100, 100), true);&#xA;&#xA;    if (!outputVideo.isOpened())&#xA;    {&#xA;        cout  &lt;&lt; "Could not open the output video for write" &lt;&lt; endl;&#xA;        return -1;&#xA;    }&#xA;    return 0;&#xA;}&#xA;

    &#xA;&#xA;

    OpenCV Configuration :

    &#xA;&#xA;

    -- Detected version of GNU GCC: 46 (406)&#xA;-- Found OpenEXR: /usr/lib/libIlmImf.so&#xA;-- Looking for linux/videodev.h&#xA;-- Looking for linux/videodev.h - not found&#xA;-- Looking for linux/videodev2.h&#xA;-- Looking for linux/videodev2.h - found&#xA;-- Looking for sys/videoio.h&#xA;-- Looking for sys/videoio.h - not found&#xA;-- Looking for libavformat/avformat.h&#xA;-- Looking for libavformat/avformat.h - found&#xA;-- Looking for ffmpeg/avformat.h&#xA;-- Looking for ffmpeg/avformat.h - not found&#xA;-- Could NOT find JNI (missing:  JAVA_INCLUDE_PATH JAVA_INCLUDE_PATH2 JAVA_AWT_INCLUDE_PATH) &#xA;-- &#xA;-- General configuration for OpenCV 2.4.8 =====================================&#xA;--   Version control:               unknown&#xA;-- &#xA;--   Platform:&#xA;--     Host:                        Linux 3.8.0-38-generic x86_64&#xA;--     CMake:                       2.8.7&#xA;--     CMake generator:             Unix Makefiles&#xA;--     CMake build tool:            /usr/bin/make&#xA;--     Configuration:               RELEASE&#xA;-- &#xA;--   C/C&#x2B;&#x2B;:&#xA;--     Built as dynamic libs?:      YES&#xA;--     C&#x2B;&#x2B; Compiler:                /usr/bin/c&#x2B;&#x2B;  (ver 4.6)&#xA;--     C&#x2B;&#x2B; flags (Release):         -fsigned-char -W -Wall -Werror=return-type -Werror=address -Werror=sequence-point -Wformat -Werror=format-security -Wmissing-declarations -Wundef -Winit-self -Wpointer-arith -Wshadow -Wsign-promo -fdiagnostics-show-option -Wno-long-long -pthread -fomit-frame-pointer -msse -msse2 -msse3 -ffunction-sections -O3 -DNDEBUG  -DNDEBUG&#xA;--     C&#x2B;&#x2B; flags (Debug):           -fsigned-char -W -Wall -Werror=return-type -Werror=address -Werror=sequence-point -Wformat -Werror=format-security -Wmissing-declarations -Wundef -Winit-self -Wpointer-arith -Wshadow -Wsign-promo -fdiagnostics-show-option -Wno-long-long -pthread -fomit-frame-pointer -msse -msse2 -msse3 -ffunction-sections -g  -O0 -DDEBUG -D_DEBUG&#xA;--     C Compiler:                  /usr/bin/gcc&#xA;--     C flags (Release):           -fsigned-char -W -Wall -Werror=return-type -Werror=address -Werror=sequence-point -Wformat -Werror=format-security -Wmissing-declarations -Wmissing-prototypes -Wstrict-prototypes -Wundef -Winit-self -Wpointer-arith -Wshadow -fdiagnostics-show-option -Wno-long-long -pthread -fomit-frame-pointer -msse -msse2 -msse3 -ffunction-sections -O3 -DNDEBUG  -DNDEBUG&#xA;--     C flags (Debug):             -fsigned-char -W -Wall -Werror=return-type -Werror=address -Werror=sequence-point -Wformat -Werror=format-security -Wmissing-declarations -Wmissing-prototypes -Wstrict-prototypes -Wundef -Winit-self -Wpointer-arith -Wshadow -fdiagnostics-show-option -Wno-long-long -pthread -fomit-frame-pointer -msse -msse2 -msse3 -ffunction-sections -g  -O0 -DDEBUG -D_DEBUG&#xA;--     Linker flags (Release):      &#xA;--     Linker flags (Debug):        &#xA;--     Precompiled headers:         YES&#xA;-- &#xA;--   OpenCV modules:&#xA;--     To be built:                 core flann imgproc highgui features2d calib3d ml video legacy objdetect photo gpu ocl nonfree contrib python stitching superres ts videostab&#xA;--     Disabled:                    world&#xA;--     Disabled by dependency:      -&#xA;--     Unavailable:                 androidcamera dynamicuda java&#xA;-- &#xA;--   GUI: &#xA;--     QT:                          NO&#xA;--     GTK&#x2B; 2.x:                    YES (ver 2.24.10)&#xA;--     GThread :                    YES (ver 2.32.4)&#xA;--     GtkGlExt:                    NO&#xA;--     OpenGL support:              NO&#xA;-- &#xA;--   Media I/O: &#xA;--     ZLib:                        /usr/lib/x86_64-linux-gnu/libz.so (ver 1.2.3.4)&#xA;--     JPEG:                        /usr/lib/x86_64-linux-gnu/libjpeg.so (ver )&#xA;--     PNG:                         /usr/lib/x86_64-linux-gnu/libpng.so (ver 1.2.46)&#xA;--     TIFF:                        /usr/lib/x86_64-linux-gnu/libtiff.so (ver 42 - 3.9.5)&#xA;--     JPEG 2000:                   /usr/lib/x86_64-linux-gnu/libjasper.so (ver 1.900.1)&#xA;--     OpenEXR:                     /usr/lib/libImath.so /usr/lib/libIlmImf.so /usr/lib/libIex.so /usr/lib/libHalf.so /usr/lib/libIlmThread.so (ver 1.6.1)&#xA;-- &#xA;--   Video I/O:&#xA;--     DC1394 1.x:                  NO&#xA;--     DC1394 2.x:                  YES (ver 2.2.0)&#xA;--     FFMPEG:                      YES&#xA;--       codec:                     YES (ver 55.58.105)&#xA;--       format:                    YES (ver 55.37.101)&#xA;--       util:                      YES (ver 52.78.100)&#xA;--       swscale:                   YES (ver 2.6.100)&#xA;--       gentoo-style:              YES&#xA;--     GStreamer:                   &#xA;--       base:                      YES (ver 0.10.36)&#xA;--       app:                       YES (ver 0.10.36)&#xA;--       video:                     YES (ver 0.10.36)&#xA;--     OpenNI:                      NO&#xA;--     OpenNI PrimeSensor Modules:  NO&#xA;--     PvAPI:                       NO&#xA;--     GigEVisionSDK:               NO&#xA;--     UniCap:                      NO&#xA;--     UniCap ucil:                 NO&#xA;--     V4L/V4L2:                    Using libv4l (ver 1.0.1)&#xA;--     XIMEA:                       NO&#xA;--     Xine:                        NO&#xA;-- &#xA;--   Other third-party libraries:&#xA;--     Use IPP:                     NO&#xA;--     Use Eigen:                   NO&#xA;--     Use TBB:                     NO&#xA;--     Use OpenMP:                  NO&#xA;--     Use GCD                      NO&#xA;--     Use Concurrency              NO&#xA;--     Use C=:                      NO&#xA;--     Use Cuda:                    NO&#xA;--     Use OpenCL:                  YES&#xA;-- &#xA;--   OpenCL:&#xA;--     Version:                     dynamic&#xA;--     Include path:                /home/shixudongleo/Downloads/opencv-2.4.8/3rdparty/include/opencl/1.2&#xA;--     Use AMD FFT:                 NO&#xA;--     Use AMD BLAS:                NO&#xA;-- &#xA;--   Python:&#xA;--     Interpreter:                 /usr/bin/python (ver 2.7.3)&#xA;--     Libraries:                   /usr/lib/libpython2.7.so&#xA;--     numpy:                       /usr/lib/python2.7/dist-packages/numpy/core/include (ver 1.6.1)&#xA;--     packages path:               lib/python2.7/dist-packages&#xA;-- &#xA;--   Java:&#xA;--     ant:                         NO&#xA;--     JNI:                         NO&#xA;--     Java tests:                  NO&#xA;-- &#xA;--   Documentation:&#xA;--     Build Documentation:         NO&#xA;--     Sphinx:                      NO&#xA;--     PdfLaTeX compiler:           /usr/bin/pdflatex&#xA;-- &#xA;--   Tests and samples:&#xA;--     Tests:                       YES&#xA;--     Performance tests:           YES&#xA;--     C/C&#x2B;&#x2B; Examples:              NO&#xA;-- &#xA;--   Install path:                  /usr/local&#xA;-- &#xA;--   cvconfig.h is in:              /home/shixudongleo/Downloads/opencv-2.4.8/build&#xA;-- -----------------------------------------------------------------&#xA;-- &#xA;-- Configuring done&#xA;-- Generating done&#xA;-- Build files have been written to: /home/XXX/Downloads/opencv-2.4.8/build&#xA;

    &#xA;&#xA;

    FFMPEG

    &#xA;&#xA;

    ffmpeg is enable to support OpenCV and libx264 is enabled when compiling ffmpeg.&#xA;By using ffmpeg command line, libx264 is running normally.

    &#xA;&#xA;

    $ ffmpeg -i test.avi -vcodec libx264 test.mp4&#xA;ffmpeg -i test.avi -vcodec libx264 test.mp4 > ~/Downloads/ffmpeg_log.txt&#xA;ffmpeg version 2.2.git Copyright (c) 2000-2014 the FFmpeg developers&#xA;  built on Apr 24 2014 16:39:51 with gcc 4.6 (Ubuntu/Linaro 4.6.3-1ubuntu5)&#xA;  configuration: --enable-gpl --enable-libfaac --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libtheora --enable-libvorbis --enable-libx264 --enable-libxvid --enable-nonfree --enable-postproc --enable-version3 --enable-x11grab --enable-shared --enable-pic&#xA;  libavutil      52. 78.100 / 52. 78.100&#xA;  libavcodec     55. 58.105 / 55. 58.105&#xA;  libavformat    55. 37.101 / 55. 37.101&#xA;  libavdevice    55. 13.100 / 55. 13.100&#xA;  libavfilter     4.  4.100 /  4.  4.100&#xA;  libswscale      2.  6.100 /  2.  6.100&#xA;  libswresample   0. 18.100 /  0. 18.100&#xA;  libpostproc    52.  3.100 / 52.  3.100&#xA;Input #0, avi, from &#x27;test.avi&#x27;:&#xA;  Duration: 00:00:03.73, start: 0.000000, bitrate: 1757 kb/s&#xA;    Stream #0:0: Video: msvideo1 (CRAM / 0x4D415243), rgb555le, 320x240, 1781 kb/s, 15 tbr, 15 tbn, 15 tbc&#xA;    Metadata:&#xA;      title           : julius.avi Video #1&#xA;File &#x27;test.mp4&#x27; already exists. Overwrite ? [y/N] y&#xA;No pixel format specified, yuv444p for H.264 encoding chosen.&#xA;Use -pix_fmt yuv420p for compatibility with outdated media players.&#xA;[libx264 @ 0x25d08e0] using cpu capabilities: none!&#xA;[libx264 @ 0x25d08e0] profile High 4:4:4 Predictive, level 1.2, 4:4:4 8-bit&#xA;[libx264 @ 0x25d08e0] 264 - core 142 - H.264/MPEG-4 AVC codec - Copyleft 2003-2014 - http://www.videolan.org/x264.html - options: cabac=1 ref=3 deblock=1:0:0 analyse=0x3:0x113 me=hex subme=7 psy=1 psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=1 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=4 threads=12 lookahead_threads=1 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=3 b_pyramid=2 b_adapt=1 b_bias=0 direct=1 weightb=1 open_gop=0 weightp=2 keyint=250 keyint_min=15 scenecut=40 intra_refresh=0 rc_lookahead=40 rc=crf mbtree=1 crf=23.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 ip_ratio=1.40 aq=1:1.00&#xA;Output #0, mp4, to &#x27;test.mp4&#x27;:&#xA;  Metadata:&#xA;    encoder         : Lavf55.37.101&#xA;    Stream #0:0: Video: h264 (libx264) ([33][0][0][0] / 0x0021), yuv444p, 320x240, q=-1--1, 15360 tbn, 15 tbc&#xA;    Metadata:&#xA;      title           : julius.avi Video #1&#xA;Stream mapping:&#xA;  Stream #0:0 -> #0:0 (msvideo1 -> libx264)&#xA;Press [q] to stop, [?] for help&#xA;frame=   56 fps=0.0 q=-1.0 Lsize=     321kB time=00:00:03.60 bitrate= 731.0kbits/s    &#xA;video:320kB audio:0kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.409949%&#xA;[libx264 @ 0x25d08e0] frame I:3     Avg QP:15.36  size:  7975&#xA;[libx264 @ 0x25d08e0] frame P:38    Avg QP:26.05  size:  6230&#xA;[libx264 @ 0x25d08e0] frame B:15    Avg QP:28.25  size:  4418&#xA;[libx264 @ 0x25d08e0] consecutive B-frames: 46.4% 53.6%  0.0%  0.0%&#xA;[libx264 @ 0x25d08e0] mb I  I16..4:  1.4% 72.8% 25.8%&#xA;[libx264 @ 0x25d08e0] mb P  I16..4:  1.6%  5.7% 15.1%  P16..4:  7.6%  6.3%  7.4%  0.0%  0.0%    skip:56.3%&#xA;[libx264 @ 0x25d08e0] mb B  I16..4:  0.2%  1.0%  2.0%  B16..8: 13.3%  7.8%  8.7%  direct: 8.3%  skip:58.8%  L0:34.9% L1:36.6% BI:28.5%&#xA;[libx264 @ 0x25d08e0] 8x8 transform intra:37.7% inter:2.3%&#xA;[libx264 @ 0x25d08e0] coded y,u,v intra: 52.1% 42.1% 30.1% inter: 19.6% 9.2% 5.2%&#xA;[libx264 @ 0x25d08e0] i16 v,h,dc,p: 56% 17% 24%  2%&#xA;[libx264 @ 0x25d08e0] i8 v,h,dc,ddl,ddr,vr,hd,vl,hu: 10% 16% 68%  1%  1%  1%  1%  1%  1%&#xA;[libx264 @ 0x25d08e0] i4 v,h,dc,ddl,ddr,vr,hd,vl,hu: 19% 18% 28%  5%  6%  5%  7%  5%  6%&#xA;[libx264 @ 0x25d08e0] Weighted P-Frames: Y:31.6% UV:21.1%&#xA;[libx264 @ 0x25d08e0] ref P L0: 70.5%  9.0% 12.1%  6.5%  2.0%&#xA;[libx264 @ 0x25d08e0] ref B L0: 91.3%  8.7%&#xA;[libx264 @ 0x25d08e0] kb/s:700.56&#xA;

    &#xA;

  • RTP packets detected as UDP

    8 juillet 2024, par fritz

    Here is what I am trying to do :

    &#xA;&#xA;

    WebRTC endpoint > RTP Endpoint > ffmpeg > RTMP server.&#xA;

    &#xA;&#xA;

    This is what my SDP file looks like.

    &#xA;&#xA;

    var cm_offer = "v=0\n" &#x2B;&#xA;              "o=- 3641290734 3641290734 IN IP4 127.0.0.1\n" &#x2B;&#xA;              "s=nginx\n" &#x2B;&#xA;              "c=IN IP4 127.0.0.1\n" &#x2B;&#xA;              "t=0 0\n" &#x2B;&#xA;              "m=audio 60820 RTP/AVP 0\n" &#x2B;&#xA;              "a=rtpmap:0 PCMU/8000\n" &#x2B;&#xA;              "a=recvonly\n" &#x2B;&#xA;              "m=video 59618 RTP/AVP 101\n" &#x2B;&#xA;              "a=rtpmap:101 H264/90000\n" &#x2B;&#xA;              "a=recvonly\n";&#xA;

    &#xA;&#xA;

    What's happening is that wireshark can detect the incoming packets at port 59618, but not as RTP packets but UDP packets. I am trying to capture the packets using ffmpeg with the following command :

    &#xA;&#xA;

    ubuntu@ip-132-31-40-100:~$ ffmpeg -i udp://127.0.0.1:59618 -vcodec copy stream.mp4&#xA;ffmpeg version git-2017-01-22-f1214ad Copyright (c) 2000-2017 the FFmpeg developers&#xA;  built with gcc 4.8 (Ubuntu 4.8.4-2ubuntu1~14.04.3)&#xA;  configuration: --extra-libs=-ldl --prefix=/opt/ffmpeg --mandir=/usr/share/man --enable-avresample --disable-debug --enable-nonfree --enable-gpl --enable-version3 --enable-libopencore-amrnb --enable-libopencore-amrwb --disable-decoder=amrnb --disable-decoder=amrwb --enable-libpulse --enable-libfreetype --enable-gnutls --enable-libx264 --enable-libx265 --enable-libfdk-aac --enable-libvorbis --enable-libmp3lame --enable-libopus --enable-libvpx --enable-libspeex --enable-libass --enable-avisynth --enable-libsoxr --enable-libxvid --enable-libvidstab --enable-libwavpack --enable-nvenc&#xA;  libavutil      55. 44.100 / 55. 44.100&#xA;  libavcodec     57. 75.100 / 57. 75.100&#xA;  libavformat    57. 63.100 / 57. 63.100&#xA;  libavdevice    57.  2.100 / 57.  2.100&#xA;  libavfilter     6. 69.100 /  6. 69.100&#xA;  libavresample   3.  2.  0 /  3.  2.  0&#xA;  libswscale      4.  3.101 /  4.  3.101&#xA;  libswresample   2.  4.100 /  2.  4.100&#xA;  libpostproc    54.  2.100 / 54.  2.100 &#xA;

    &#xA;&#xA;

    All I get is a blinking cursor and The stream.mp4 file is not written to disk after I exit (ctrl+c).

    &#xA;&#xA;

    So can you help me figure out :

    &#xA;&#xA;

      &#xA;
    1. why wireshark cannot detect the packets as RTP (I suspect it has something to do with SDP)
    2. &#xA;

    3. How to handle SDP answer when the RTP endpoint is pushing to ffmpeg which doesn't send an answer back.
    4. &#xA;

    &#xA;&#xA;

    Here is the entire code (hello world tutorial modified)

    &#xA;&#xA;

    /*&#xA;     * (C) Copyright 2014-2015 Kurento (http://kurento.org/)&#xA;     *&#xA;     * Licensed under the Apache License, Version 2.0 (the "License");&#xA;     * you may not use this file except in compliance with the License.&#xA;     * You may obtain a copy of the License at&#xA;     *&#xA;     *   http://www.apache.org/licenses/LICENSE-2.0&#xA;     *&#xA;     * Unless required by applicable law or agreed to in writing, software&#xA;     * distributed under the License is distributed on an "AS IS" BASIS,&#xA;     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.&#xA;     * See the License for the specific language governing permissions and&#xA;     * limitations under the License.&#xA;     */&#xA;&#xA;    function getopts(args, opts)&#xA;    {&#xA;      var result = opts.default || {};&#xA;      args.replace(&#xA;          new RegExp("([^?=&amp;]&#x2B;)(=([^&amp;]*))?", "g"),&#xA;          function($0, $1, $2, $3) { result[$1] = decodeURI($3); });&#xA;&#xA;      return result;&#xA;    };&#xA;&#xA;    var args = getopts(location.search,&#xA;    {&#xA;      default:&#xA;      {&#xA;        ws_uri: &#x27;wss://&#x27; &#x2B; location.hostname &#x2B; &#x27;:8433/kurento&#x27;,&#xA;        ice_servers: undefined&#xA;      }&#xA;    });&#xA;&#xA;    function setIceCandidateCallbacks(webRtcPeer, webRtcEp, onerror)&#xA;    {&#xA;      webRtcPeer.on(&#x27;icecandidate&#x27;, function(candidate) {&#xA;        console.log("Local candidate:",candidate);&#xA;&#xA;        candidate = kurentoClient.getComplexType(&#x27;IceCandidate&#x27;)(candidate);&#xA;&#xA;        webRtcEp.addIceCandidate(candidate, onerror)&#xA;      });&#xA;&#xA;      webRtcEp.on(&#x27;OnIceCandidate&#x27;, function(event) {&#xA;        var candidate = event.candidate;&#xA;&#xA;        console.log("Remote candidate:",candidate);&#xA;&#xA;        webRtcPeer.addIceCandidate(candidate, onerror);&#xA;      });&#xA;    }&#xA;&#xA;&#xA;    function setIceCandidateCallbacks2(webRtcPeer, rtpEp, onerror)&#xA;    {&#xA;      webRtcPeer.on(&#x27;icecandidate&#x27;, function(candidate) {&#xA;        console.log("Localr candidate:",candidate);&#xA;&#xA;        candidate = kurentoClient.getComplexType(&#x27;IceCandidate&#x27;)(candidate);&#xA;&#xA;        rtpEp.addIceCandidate(candidate, onerror)&#xA;      });&#xA;    }&#xA;&#xA;&#xA;    window.addEventListener(&#x27;load&#x27;, function()&#xA;    {&#xA;      console = new Console();&#xA;&#xA;      var webRtcPeer;&#xA;      var pipeline;&#xA;      var webRtcEpt;&#xA;&#xA;      var videoInput = document.getElementById(&#x27;videoInput&#x27;);&#xA;      var videoOutput = document.getElementById(&#x27;videoOutput&#x27;);&#xA;&#xA;      var startButton = document.getElementById("start");&#xA;      var stopButton = document.getElementById("stop");&#xA;&#xA;      startButton.addEventListener("click", function()&#xA;      {&#xA;        showSpinner(videoInput, videoOutput);&#xA;&#xA;        var options = {&#xA;          localVideo: videoInput,&#xA;          remoteVideo: videoOutput&#xA;        };&#xA;&#xA;&#xA;        if (args.ice_servers) {&#xA;         console.log("Use ICE servers: " &#x2B; args.ice_servers);&#xA;         options.configuration = {&#xA;           iceServers : JSON.parse(args.ice_servers)&#xA;         };&#xA;        } else {&#xA;         console.log("Use freeice")&#xA;        }&#xA;&#xA;        webRtcPeer = kurentoUtils.WebRtcPeer.WebRtcPeerSendrecv(options, function(error)&#xA;        {&#xA;          if(error) return onError(error)&#xA;&#xA;          this.generateOffer(onOffer)&#xA;        });&#xA;&#xA;        function onOffer(error, sdpOffer)&#xA;        {&#xA;          if(error) return onError(error)&#xA;&#xA;          kurentoClient(args.ws_uri, function(error, client)&#xA;          {&#xA;            if(error) return onError(error);&#xA;&#xA;            client.create("MediaPipeline", function(error, _pipeline)&#xA;            {&#xA;              if(error) return onError(error);&#xA;&#xA;              pipeline = _pipeline;&#xA;&#xA;              pipeline.create("WebRtcEndpoint", function(error, webRtc){&#xA;                if(error) return onError(error);&#xA;&#xA;                webRtcEpt = webRtc;&#xA;&#xA;                setIceCandidateCallbacks(webRtcPeer, webRtc, onError)&#xA;&#xA;                webRtc.processOffer(sdpOffer, function(error, sdpAnswer){&#xA;                  if(error) return onError(error);&#xA;&#xA;                  webRtcPeer.processAnswer(sdpAnswer, onError);&#xA;                });&#xA;                webRtc.gatherCandidates(onError);&#xA;&#xA;                webRtc.connect(webRtc, function(error){&#xA;                  if(error) return onError(error);&#xA;&#xA;                  console.log("Loopback established");&#xA;                });&#xA;              });&#xA;&#xA;&#xA;&#xA;            pipeline.create("RtpEndpoint", function(error, rtp){&#xA;                if(error) return onError(error);&#xA;&#xA;                //setIceCandidateCallbacks2(webRtcPeer, rtp, onError)&#xA;&#xA;&#xA;                var cm_offer = "v=0\n" &#x2B;&#xA;                      "o=- 3641290734 3641290734 IN IP4 127.0.0.1\n" &#x2B;&#xA;                      "s=nginx\n" &#x2B;&#xA;                      "c=IN IP4 127.0.0.1\n" &#x2B;&#xA;                      "t=0 0\n" &#x2B;&#xA;                      "m=audio 60820 RTP/AVP 0\n" &#x2B;&#xA;                      "a=rtpmap:0 PCMU/8000\n" &#x2B;&#xA;                      "a=recvonly\n" &#x2B;&#xA;                      "m=video 59618 RTP/AVP 101\n" &#x2B;&#xA;                      "a=rtpmap:101 H264/90000\n" &#x2B;&#xA;                      "a=recvonly\n";&#xA;&#xA;&#xA;&#xA;                rtp.processOffer(cm_offer, function(error, cm_sdpAnswer){&#xA;                  if(error) return onError(error);&#xA;&#xA;                  //webRtcPeer.processAnswer(cm_sdpAnswer, onError);&#xA;                });&#xA;                //rtp.gatherCandidates(onError);&#xA;&#xA;                webRtcEpt.connect(rtp, function(error){&#xA;                  if(error) return onError(error);&#xA;&#xA;                  console.log("RTP endpoint connected to webRTC");&#xA;                });&#xA;              });&#xA;&#xA;&#xA;&#xA;&#xA;&#xA;&#xA;&#xA;&#xA;&#xA;            });&#xA;          });&#xA;        }&#xA;      });&#xA;      stopButton.addEventListener("click", stop);&#xA;&#xA;&#xA;      function stop() {&#xA;        if (webRtcPeer) {&#xA;          webRtcPeer.dispose();&#xA;          webRtcPeer = null;&#xA;        }&#xA;&#xA;        if(pipeline){&#xA;          pipeline.release();&#xA;          pipeline = null;&#xA;        }&#xA;&#xA;        hideSpinner(videoInput, videoOutput);&#xA;      }&#xA;&#xA;      function onError(error) {&#xA;        if(error)&#xA;        {&#xA;          console.error(error);&#xA;          stop();&#xA;        }&#xA;      }&#xA;    })&#xA;&#xA;&#xA;    function showSpinner() {&#xA;      for (var i = 0; i &lt; arguments.length; i&#x2B;&#x2B;) {&#xA;        arguments[i].poster = &#x27;img/transparent-1px.png&#x27;;&#xA;        arguments[i].style.background = "center transparent url(&#x27;img/spinner.gif&#x27;) no-repeat";&#xA;      }&#xA;    }&#xA;&#xA;    function hideSpinner() {&#xA;      for (var i = 0; i &lt; arguments.length; i&#x2B;&#x2B;) {&#xA;        arguments[i].src = &#x27;&#x27;;&#xA;        arguments[i].poster = &#x27;img/webrtc.png&#x27;;&#xA;        arguments[i].style.background = &#x27;&#x27;;&#xA;      }&#xA;    }&#xA;&#xA;    /**&#xA;     * Lightbox utility (to display media pipeline image in a modal dialog)&#xA;     */&#xA;    $(document).delegate(&#x27;*[data-toggle="lightbox"]&#x27;, &#x27;click&#x27;, function(event) {&#xA;      event.preventDefault();&#xA;      $(this).ekkoLightbox();&#xA;    });&#xA;

    &#xA;