Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
13 changes: 12 additions & 1 deletion portable-devices/mobile/src/modules/navigation/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import { createBottomTabNavigator } from '@react-navigation/bottom-tabs';
import { NavigationContainer } from '@react-navigation/native';

import { RootAppNavigators, resolveRootRoute } from '../../react-navigation';
import { Dashboard, Hello, Settings, PersonalInfo } from '../../pages';
import { Dashboard, Hello, Settings, PersonalInfo,CameraScreen } from '../../pages';

export const Navigation = () => {
const rootRoutes: RootAppNavigators = {
Expand Down Expand Up @@ -80,6 +80,17 @@ export const Navigation = () => {
},
},
},
CameraScreen: {
props: {
initialParams: {},
component: Settings,
options: {
headerShown: true,
headerTitle: 'Camera',
headerBackTitle: 'Back',
},
},
},
},
},
};
Expand Down
97 changes: 97 additions & 0 deletions portable-devices/mobile/src/pages/CameraScreen.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,97 @@
import React, { useState, useEffect } from 'react';
import { StyleSheet ,Text, View, TouchableOpacity, Image} from 'react-native';
import { Camera } from 'expo-camera';

export default function CameraScreen() {
const [hasCameraPermission, setHasCameraPermission] = useState(null);
const [camera, setCamera] = useState(null);
const [image, setImage] = useState(null);
const [type, setType] = useState(Camera.Constants.Type.back);
useEffect(() => {
(async () => {
const cameraStatus = await Camera.requestCameraPermissionsAsync();
setHasCameraPermission(cameraStatus.status === 'granted');
})();
}, []);
const ask = async() =>{
await Camera.requestCameraPermissionsAsync();
//setHasCameraPermission(cameraStatus.status === 'granted');
}
const takePicture = async () => {
if(camera){
const data = await camera.takePictureAsync(null)
setImage(data.uri);
}
}

if (hasCameraPermission === false) {
// return <View style={{
// flex: 1,
// alignItems:'center',
// justifyContent:'center'
// }}><Text>No access to camera</Text></View>;
ask();
}
return (
<View style={{ flex: 1,}}>
<View style={styles.cameraContainer}>
<Camera
ref={ref => setCamera(ref)}
style={styles.fixedRatio}
type={type}
ratio={'16:9'} />
</View>
<View style={styles.buttonContainer}>
<TouchableOpacity style={styles.btnColor}
onPress={() => {
setType(
type === Camera.Constants.Type.back
? Camera.Constants.Type.front
: Camera.Constants.Type.back
);
}}>
<Text style={styles.textStyle}>Flip Camera</Text>
</TouchableOpacity>
<TouchableOpacity style={styles.btnColor} onPress={() => takePicture()}>
<Text style={styles.textStyle}>Take Picture</Text>
</TouchableOpacity>
{image && <Image source={{uri: image}} style={{width:100,height:100}}/>}
</View>

</View>
);
}
const styles = StyleSheet.create({
cameraContainer: {
flex: 1,
flexDirection: 'row',
//alignItems:'center',
justifyContent:'center'
},
fixedRatio:{
//flex: 1,
width:'100%',
height:'80%',
},
buttonContainer:{
width:'80%',
alignSelf:'center',
alignItems:'center',
justifyContent:'center',
marginBottom:20
},
btnColor: {
padding: 10,
paddingHorizontal:20,
borderRadius: 40,
backgroundColor: '#eee',
marginTop: 10,
},
textStyle:{
fontSize:20,
fontWeight:'bold',
textAlign:'center'

}
})

4 changes: 2 additions & 2 deletions portable-devices/mobile/src/pages/index.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import Dashboard from './dashboard';
import Hello from './hello';

impoert CameraScreen from './CameraScreen';
export * from './Settings';
export * from './PersonalInfo';
export { Dashboard, Hello };
export { Dashboard, Hello,CameraScreen };