- Clone this repo and open terminal.
cd
to the directory of README.md.- run
yarn install
. - run
yarn dev
, this will host the app in local environment or you can host thesrc
folder on other place can access. - copy
https://127.0.0.1:5173/
or URL if you host on the place to test-app 'Video app url' input box and then click 'Load' button. - change
videoFrameHandler
function insrc/index.js
- This sample processes the video frame in main thread for simplicity, you can move the frame processing to worker thread if needed.
You can find the Teams video extensibility API link
There are three API for video extensibility
registerForVideoFrame(frameCallback, config)
- video frames from video pipeline.
- a callback to return processed video frames to video pipeline.
- a callback to notify error
registerForVideoEffect(callback)
- Get notification that the selected effect in video app’s UI should be applied
notifySelectedVideoEffectChanged(
effectChangeType,
effectId,
)
- Whenever the user selects a different effect in a video app, the video app should call this API to notify Teams client.
- Host the app directory in a public accessible HTTPS server. You can use github page as the host.
- Replace the
name
,appId
, andcontentUrl
inmanifest/manifest.json
.- The contentUrl should point to your app directory, like
https://github.com/microsoft/teams-videoapp-sample/app/
- appId can be any unique GUID
- The contentUrl should point to your app directory, like
- zip the manifest directory, choose the zip file after clicking Upload a custom app
- Go to a teams meeting, enable the video, and activate the video app.
- You can get more information on Video app developer guide
This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.
When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft trademarks or logos is subject to and must follow Microsoft's Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship. Any use of third-party trademarks or logos are subject to those third-party's policies.