Көпэкранды қосымша
Автор: Gul2311 • Март 10, 2023 • Лабораторная работа • 843 Слов (4 Страниц) • 150 Просмотры
Әл-Фараби атындағы Қазақ Ұлттық Университеті
[pic 1]
Ақпараттық Технологиялар Факультеті
Ақпараттық Жүйелер мамандығы
СӨЖ
Тақырып:
Көпэкранды қосымша
Орындаған: Қадыров Бекжан
Тексерген: Бидахмет Ж. Б.
Алматы
2022
Тапсырма. Келесі мүмкіндіктерді қамтамасыз ететін көп терезелі қосымшаны әзірлеу: аудио және бейне файлдарды ойнату, фотосуреттерді жасау және көрсету.
- Видеоны ойнату және ойнатылатын кез келген видеоны таңдау
import { StatusBar } from 'expo-status-bar';
import { StyleSheet, Button, View } from 'react-native';
import { Video } from 'expo-av';
import React from 'react';
export default function App() {
const video = React.useRef(null);
const secondVideo = React.useRef(null);
const [status, setStatus] = React.useState({});
const [statusSecondVideo, setStatusSecondVideo] = React.useState({});
return (
<View style={styles.container}>
<Video
ref={video}
style={styles.video}
source={{uri: "http://d23dyxeqlo5psv.cloudfront.net/big_buck_bunny.mp4"}}
useNativeControls
resizeMode="contain"
isLooping
onPlaybackStatusUpdate={setStatus}
/>
<View style={styles.buttons}>
<Button title="Play from 5s" onPress={() => video.current.playFromPositionAsync(5000)} />
<Button title={status.isLooping ? "Set to not loop" : "Set to loop"} onPress={() => video.current.setIsLoopingAsync(!status.isLooping)} />
</View>
<Video
ref={secondVideo}
style={styles.video}
source={require("./demo.mp4")}
useNativeControls
resizeMode="contain"
isLooping
onPlaybackStatusUpdate={setStatusSecondVideo}
/>
<View style={styles.buttons}>
<Button title="Play from 50s" onPress={() => secondVideo.current.playFromPositionAsync(50000)} />
<Button title={statusSecondVideo.isLooping ? "Set to not loop" : "Set to loop"} onPress={() => secondVideo.current.setIsLoopingAsync(!statusSecondVideo.isLooping)} />
</View>
<StatusBar style="auto" />
</View>
);
}
const styles = StyleSheet.create({
container: {
flex: 1,
backgroundColor: '#fff',
alignItems: 'center',
justifyContent: 'center',
},
video: {
flex: 1,
alignSelf: 'stretch'
},
buttons: {
margin: 16
}
});
[pic 2]
- Фотосурет түсіру, фотосуретті көрсету, көрсету үшін кез келген суретті жүктеу
import React, { useState } from "react";
import {
ActivityIndicator,
Button,
FlatList,
Image,
StyleSheet,
Text,
useWindowDimensions,
...