AI编程助手
AI免费问答

uniapp如何实现直播

coldplay.xixi   2020-12-15 17:50   14008浏览 原创

 

uniapp实现直播的方法:首先通过推流,代码为【开始推流】;然后使用video标签实现拉流即可。

本教程操作环境:windows7系统、uni-app2.5.1版本,Dell G3电脑。

uniapp实现直播的方法:

1、推流

<template>
    <view>
        <template>
            <view>
                <live-pusher></live-pusher>
                <button>开始推流</button>
                <button>暂停推流</button>
                <button>resume</button>
                <button>停止推流</button>
                <button>快照</button>
                <button>开启摄像头预览</button>
                <button>关闭摄像头预览</button>
                <button>切换摄像头</button>
                <button>去播放</button>
            </view>
        </template>
    </view></template><script>
export default {
    data() {
        return {
            context:[]
        };
    },
    onReady() {
        // 注意:需要在onReady中 或 onLoad 延时
        this.context = uni.createLivePusherContext(&#39;livePusher&#39;, this);
    },
    methods: {
        statechange(e) {
            console.log(&#39;statechange:&#39; + JSON.stringify(e));
        },
        netstatus(e) {
            console.log(&#39;netstatus:&#39; + JSON.stringify(e));
        },
        error(e) {
            console.log(&#39;error:&#39; + JSON.stringify(e));
        },
        start(){
            this.context.start({
                success: a => {
                    console.log(&#39;livePusher.start:&#39; + JSON.stringify(a));
                },
                error:err=>{
                    console.log(err)
                }
            });
        },
        close() {
            this.context.close({
                success: a => {
                    console.log(&#39;livePusher.close:&#39; + JSON.stringify(a));
                }
            });
        },
        snapshot() {
            this.context.snapshot({
                success: e => {
                    console.log(JSON.stringify(e));
                }
            });
        },
        resume() {
            this.context.resume({
                success: a => {
                    console.log(&#39;livePusher.resume:&#39; + JSON.stringify(a));
                }
            });
        },
        pause() {
            this.context.pause({
                success: a => {
                    console.log(&#39;livePusher.pause:&#39; + JSON.stringify(a));
                }
            });
        },
        stop() {
            this.context.stop({
                success: a => {
                    console.log(JSON.stringify(a));
                }
            });
        },
        switchCamera() {
            this.context.switchCamera({
                success: a => {
                    console.log(&#39;livePusher.switchCamera:&#39; + JSON.stringify(a));
                }
            });
        },
        startPreview() {
            this.context.startPreview({
                success: a => {
                    console.log(&#39;livePusher.startPreview:&#39; + JSON.stringify(a));
                }
            });
        },
        stopPreview() {
            this.context.stopPreview({
                success: a => {
                    console.log(&#39;livePusher.stopPreview:&#39; + JSON.stringify(a));
                }
            });
        },
        bofang(){
            this.$u.route({
                url: &#39;pages/index/index&#39;
            })
        }
    }
};
</script><style>
.content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.logo {
    height: 200rpx;
    width: 200rpx;
    margin-top: 200rpx;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 50rpx;
}
.text-area {
    display: flex;
    justify-content: center;
}
.title {
    font-size: 36rpx;
    color: #8f8f94;
}
</style>
**

2、拉流

这里是app拉流,用的是video标签,代码如下

<template>
    <view>
        <video></video>
    </view></template>
 
<script>
    export default {}
</script>

src是请求接口得到的拉流地址

相关免费学习推荐:php编程(视频)

推荐(免费):uni-app开发教程

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。