I've ran Janus on a server and it works fine, but I'm kind of struggling finding a way to stream on the Janus server, I could not find any snippet code out there, I am developing with Vue.js, is there any library to stream over Janus? I just need a sample.
Streaming over Janus using Vue.js
1.8k Views Asked by Hossein Heydari At
1
There are 1 best solutions below
Related Questions in JAVASCRIPT
- Using Puppeteer to scrape a public API only when the data changes
- inline SVG text (js)
- An array of images and a for loop display the buttons. How to assign each button to open its own block by name?
- Storing the preferred font-size in localStorage
- Simple movie API request not showing up in the console log
- Authenticate Flask rest API
- Deploying sveltekit app with gunjs on vercel throws cannot find module './lib/text-encoding'
- How to request administrator rights?
- mp4 embedded videos within github pages website not loading
- Scrimba tutorial was working, suddenly stopped even trying the default
- In Datatables, start value resets to 0, when column sorting
- How do I link two models in mongoose?
- parameter values only being sent to certain columns in google sheet?
- Run main several times of wasm in browser
- Variable inside a Variable, not updating
Related Questions in VUE.JS
- Problems with matter.js and i18n in vue.js
- Form Validation not working in custom component Vue
- Authenticating vue app on each route change
- Vue/TailwindCSS - Content is behind Sidebar
- Vue3 Suspense Parent > Child Animation
- Pass dynamic object data via nuxt-link to component
- Failed to resolve import, but the path is valid, and detected as such by VSCode
- how to use less variables in vue components?
- Prevent a webpage from navigating away
- Creating a modal window in product edit page in Shopware6 and saving data to custom table(repository) from a form within the modal window
- How do I fix (or ignore) a TypeScript error that's inside a HTML template?
- Vue.js Checkbox Alignment Issue: Centering Checkboxes Within Table Cells
- How to reset vue product filter?
- Vue display output of two dimensional array
- vue js error when adding bonus items to another item
Related Questions in JANUS-GATEWAY
- Janus WEBRTC issue on media stream conection stability
- Vonage webhook event return error: Can't connect to outbound destination number that is linked to the same application
- I'm installing rocky linux 8.9 in my virtual box But, there is a problem
- Janus-gateway "join" http call return "ack" only
- Janus in Kubernetes failed in ICE connectivity, while in docker it works
- Saving incoming webRTC stream to blob in node environment
- Janus Gateway and datachannels using a raspberry pi
- Signed tokens for Janus webRTC
- Janus Demo testing
- Janus mjr having loss of packets issue
- How to fix these Warnings that appear after installing Janus WebRTC and Redis on Ubuntu 20.04 LTS?
- Why the webrtc android camera stream is rotated at endpoint?
- Receive, process and send multiple streams in python server
- WebRTC video / audio stream in mobile browser will not play in background like a typical video
- How to setup the following different parameters of JANUS-WebRTC-GATEWAY?
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
Janus Gateway has a streaming plugin. You need to enable the plugin and use some software like gstreamer or ffmpeg to transfer video data to the streaming plugin. The Q&A shows how to do this on Raspberry Pi. https://superuser.com/questions/1458442/h264-stream-to-janus-using-ffmpeg-on-raspberry-pi
Short summary is below.
Set up Janus gateway streaming plugin
The streaming plugin configuration file is
/opt/janus/etc/janus/janus.plugin.streaming.jcfg. (official documentation)You can find there are several sample configurations. For example,
rtp-samplereceives VP8/Opus video streaming data via RTP. If you want to stream H.264 video, you can edit the configuration to add this setting.After editing the configuration, you need to restart Janus gateway.
Start video streaming
You can send video data to Janus streaming plugin via RTP. For example, if you have FFMpeg, you can do like this.
This command reads video data from
/dev/video0and Please note the video parameters and output RTP port number (8084in above example) should be corresponding to the Janus streaming plugin configuration.Prepare Vue.js frontend
Next step is a frontend. You can create web frontend to view the streaming using janus.js bundled in Janus gateway. As described in the official documantation, you can use the janus.js as JavaScript module. But when you want to use it from Vue.js, you will need export-loader.
For example, you can create Vue.js2 project and add janus.js like this.
To add Webpack configuration, you need to create
vue.config.jsfile with following content.Then, you can import
Janusobject from Vue.js module like this.Then you can use janus.js and receive streaming video data using APIs.
I uploaded example Vue.js project, which might also help you.