ReactJS - 来自网络摄像头的视频流不起作用

Che*_*nzo 5 javascript webcam html5-video reactjs

我不确定为什么这不起作用。我正在接收相机流并且它正在工作,因为我的相机上有光。

流似乎没有附加。



class VideoOutput extends React.Component {
    constructor(props) {
        super(props);
        this.videoRef = React.createRef();
    }

    componentDidMount() {
        const videoObj = this.videoRef.current;
        videoObj.srcObject = this.props.video;
        console.log(videoObj);
    }

    render() {
        return <video ref={this.videoRef}></video>;
    }
}


class Application extends React.Component {

  constructor(props) {
    super(props);
    this.state = {
      video: null
    };

    this.handleVideoClick = this.handleVideoClick.bind(this);
  }


  async getVideo() {
    const video = await navigator.mediaDevices.getUserMedia({
      audio: false,
      video: true
    });
    this.setState({ video });
  }

  stopVideo() {
    this.state.video.getTracks().forEach(track => track.stop());
    this.setState({ video: null });
  }


  handleVideoClick() {
    if (this.state.video) {
      this.stopVideo();
    } else {
      this.getVideo();
    } 
  }

  render(){
    return(
      <div>
          <button onClick={this.handleVideoClick}>
            {this.state.video ? 'Vid On' : 'Vid Off'}
          </button>
      <div>
      {this.state.video ? <VideoOutput video={this.state.video} /> : ''}
       </div>
       </div>
    );
  }


}

ReactDOM.render(<Application />, document.getElementById('root'));
Run Code Online (Sandbox Code Playgroud)

此处不起作用的示例:https : //codepen.io/Chenzo/pen/QXXVvr

这似乎是它应该工作,我......但我怀疑我失去了一些东西简单。

Bra*_*rad 5

我怀疑问题在于您没有播放视频。设置后尝试添加srcObject

videoObj.play();
Run Code Online (Sandbox Code Playgroud)