首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >获取expo-camera ref以开始在功能组件中录制视频

获取expo-camera ref以开始在功能组件中录制视频
EN

Stack Overflow用户
提问于 2020-05-06 14:04:53
回答 1查看 761关注 0票数 0

我正在试着让世博会的摄像机来录制视频。但是,我得到了一个错误:

代码语言:javascript
复制
[TypeError: camera.recordAsync is not a function. (In ‘camera.recordAsync()’, ‘camera.recordAsync’ is undefined)]

这是实现:

代码语言:javascript
复制
<Camera 
                style={{ flex: 1 }} 
                type={type}
                ref={camera}
            >
                <View
                style={{
                    flex: 1,
                    backgroundColor: 'transparent',
                    flexDirection: 'row',
                }}>
                <View style={{ alignSelf: 'flex-end', alignItems: 'center', padding: 20, flexDirection: 'row', justifyContent: 'space-between', width: '100%'}}>
                    <MaterialIcons name="video-library" onPress={pickVideo} color={"#eee"} size={45}/>     
                    <RecordingIcon />    
                    <Ionicons name="ios-reverse-camera" onPress={setCameraType} color={"#eee"} size={45}/>                     
                </View>
                </View>
            </Camera>

重要的一行是RecordingIcon。

代码语言:javascript
复制
function RecordingIcon (){
        if(recording){
            stopRecording()
            return (
                <MaterialIcons name="fiber-manual-record" onPress={() => setRecording(false)} color={"#FF0000"} size={60}/>  
            )
        } else {
            record()
            return (
                <MaterialIcons name="fiber-manual-record" onPress={() => setRecording(true)} color={"#eee"} size={60}/>  
            )
        }
    }

每次我点击录制图标时,就会调用这两个函数中的一个。

代码语言:javascript
复制
async function record(){
        console.log("record", camera); 
        if(camera){
            let recording = await camera.recordAsync(); 
        }
    }

    async function stopRecording(){
        console.log("stop recording", camera); 
        if(camera){
            let stopRecording = await camera.stopRecording(); 
        }
    }

代码语言:javascript
复制
async function record(){
        console.log("record", camera); 
        if(camera){
            let recording = await camera.recordAsync(); 
        }
    }

    async function stopRecording(){
        console.log("stop recording", camera); 
        if(camera){
            let stopRecording = await camera.stopRecording(); 
        }
    }

这就是我初始化相机引用的方式。

代码语言:javascript
复制
let camera = useRef(null);
EN

回答 1

Stack Overflow用户

发布于 2021-05-17 18:39:30

使用camera.current

代码语言:javascript
复制
async function record(){
    console.log("record", camera); 
    if(camera){
        let recording = await camera.current.recordAsync(); 
    }
}
async function stopRecording(){
   console.log("stop recording", camera); 
   if(camera){
       let stopRecording = await camera.current.stopRecording(); 
   }
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61628442

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档