ReactNative: 使用滑块组件Slider组件

Posted xyq-208910

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ReactNative: 使用滑块组件Slider组件相关的知识,希望对你有一定的参考价值。

一、简介

滑块组件Slider组件是一个跨平台的组件,用户可以拖拽它的值来调整播放或浏览的进度,例如音乐、视频、电子书等等。

 

二、API

它的API如下所示:

//滑块组件风格布局
style: ViewPropTypes.style

//滑块的初始值。 该值应介于minimumValue和maximumValue之间,分别默认为0和1。 预设值为0。
value: PropTypes.number

//滑块的步长值。 该值应介于0到(maximumValue-minimumValue)之间。 预设值为0。
step: PropTypes.number

//滑块的最小值, 默认为0
minimumValue: PropTypes.number

//滑块的最大值, 默认为1
maximumValue: PropTypes.number

//滑块按钮左侧轨道的颜色。覆盖ios上的默认蓝色渐变图像
minimumTrackTintColor: ColorPropType

//滑块按钮右侧轨道的颜色。覆盖iOS上的默认蓝色渐变图像
maximumTrackTintColor: ColorPropType

//滑块是否可交互
disabled: PropTypes.bool

//当前滑块的轨道图像。 仅支持静态图像。
trackImage: Image.propTypes.source

//分配最小轨道图像。 仅支持静态图像。
minimumTrackImage: Image.propTypes.source

//分配最大轨道图像。 仅支持静态图像。
maximumTrackImage: Image.propTypes.source

//为滑块设置图像。 仅支持静态图像。
thumbImage: Image.propTypes.source

//为滑块设置颜色, 仅限安卓使用
thumbTintColor: ColorPropType

//滑块值改变时的回调
onValueChange: PropTypes.func

//滑块滑动终点时调用
onSlidingComplete: PropTypes.func

//唯一标识
testID: PropTypes.string

 

三、使用

简单使用如下:

/**
 * Sample React Native App
 * https://github.com/facebook/react-native
 * @flow
 */

import React, { Component } from react;

import {
    AppRegistry,
    StyleSheet,
    View,
    Slider
} from react-native;


export default class ReactNativeDemo extends Component {

    render() {
        return (
            <View style={[styles.flex,styles.bgColor,styles.center]}>
                <View style={{marginTop: 80 , marginLeft: 40}}>
                    <Slider
                        style={{width:300}}
                        value={0.3}
                        step={0}
                        minimumValue={0}
                        maximumValue={1}
                        minimumTrackTintColor={red}
                        maximumTrackTintColor={green}
                        onValueChange={ (value) => {console.log(value:+value)}}
                        onSlidingComplete={ () => {console.log(onSlidingComplete)}}
                    />
                </View>
                <View style={{marginTop: 140 , marginLeft: 40}}>
                    <Slider
                        style={{width:300}}
                        value={0.3}
                        step={0}
                        minimumValue={0}
                        maximumValue={1}
                        // trackImage={{uri:‘trackImage.png‘,scale:2}}
                        // minimumTrackImage={{uri:‘minimumTrackImage.png‘,scale:2}}
                        // maximumTrackImage={{uri:‘maximumTrackImage.png‘,scale:2}}
                        thumbImage={{uri:thumbImage.png,scale:2}}
                        onValueChange={ (value) => {console.log(value:+value)}}
                        onSlidingComplete={ () => {console.log(onSlidingComplete)}}
                    />
                </View>
            </View>
        );
    }
}

const styles = StyleSheet.create({
    flex: {
        flex: 1
    },
    bgColor: {
      backgroundColor: white
    },
    center: {
        //alignItems: ‘center‘,
        justifyContent: center,
    }
});

AppRegistry.registerComponent(ReactNativeDemo, () => ReactNativeDemo);

技术图片

 

以上是关于ReactNative: 使用滑块组件Slider组件的主要内容,如果未能解决你的问题,请参考以下文章

#夏日挑战赛# HarmonyOS - 自定义组件之slider滑块

微信小程序 写音乐播放器 slider组件 将value设置为0 真机测试滑块不能回到起点

Slider滑块实现进度条

React-Native Slider滑竿使用

CPP / JUCE 音频编程框架 - 滑块阵列不工作 - 单滑块工作

反应。将不同的数据阵列加载到光滑的滑块中