当前位置: 首页 > news >正文

React Native 实现滑一点点内容区块指示器也滑一点点

效果图如上,内容滑一点点,指示器也按比例话一点点,列表宽度跟数据有关。

实现思路如下:

1.监听列表滑动事件,获取列表横向滑动距离,假设为A;

2.获取列表的宽度,及列表可滑动的宽度,假设为B;

3.获取指示器宽度,及指示器可滑动的宽度;假设为C;

4.计算指示器滑动距离,假设为X;

5.根据 滑动距离/列表可滑宽度 = 滑动距离/指示器可滑宽度,得出A/B=X/C,

所以X= A/B * C,把ABC数据带进来,即可算出指示器滑动距离,并设置给指示器item的左间距。

代码实现如下:UI样式如下

<View> 
                <FlatList
                    horizontal={true}
                    showsHorizontalScrollIndicator={false}
                    data={tripData}
                    renderItem={({item, index, separators}) => this.renderItem(item, index, length)}
                    keyExtractor={(item, index) => index.toString()}
                    renderScrollComponent={props => (<ScrollView {...props} />)}
                    getItemLayout={(data, index) => ({length: this.vItemWidth, offset: (this.vItemWidth + 5) * index, index})}
                    onTouchStart={(e) => this.scrollEnable(false)}
                    onTouchCancel={(e) => this.scrollEnable(true)}
                    onScroll={this.onScroll}/>

                {this.renderIndicator()}
            </View>


renderIndicator() {
        return(
            <View style={styles.indicatorContainer}>
                <View
                    ref={(view) => {this.indicatorView = view;}}
                    style={[styles.indicatorItem]}/>
            </View>);
    };

scrollEnable(enable) {
         //处理一些滑动冲突事件
    }

renderItem(item, index, length) {
//item的样式
}


滑动算法如下:

onScroll = (event) => { 
        let nativeEvent = {...event.nativeEvent};
        let offsetX = nativeEvent.contentOffset.x;//用户横向滑动距离
        let indicatorWidth = styles.indicatorContainer.width;//指示器容器宽度
        let indicatorItemWidth = styles.indicatorItem.width;  //指示器宽度
        let indicatorLeft = offsetX / this.slideWidth * (indicatorWidth - indicatorItemWidth); 
        this.indicatorView.setNativeProps({
            marginLeft: indicatorLeft
        }); 
    };



//列表可滑距离=列表总宽度 - 单屏宽度
列表总宽度= item的宽度 * item的个数 + item间间距 * (item个数 - 1) + 左间距 + 有间距;
列表可滑距离 = 列表总宽度 - 单屏显示的宽度;

相关文章:

  • linux启程指南——体悟虚拟开源天地的漫步翩翩
  • <03.04>八股文
  • HttpServletRequest、ServerHttpRequest 和 ServerWebRequest作用详解
  • K8S学习之基础九:pod的生命周期
  • Ubuntu20.04双系统安装及软件安装(四):国内版火狐浏览器
  • linux应用:errno、perror、open、fopen
  • StableDifussion初学(模型选择区)
  • 除了DeepSpeed,在训练和推理的时候,显存不足还有什么优化方法吗?FlashAttention 具体是怎么做的
  • Gartner发布安全运营指标构建指南
  • SpringMVC 的配置及拦截器
  • 浅谈开发基于DeepSeek的编程辅助插件需要系统性的技术规划和实施方案
  • Python+Vue+数据可视化的考研知识共享平台(源码+论文+讲解+安装+调试+售后)
  • 【HarmonyOS Next】自定义Tabs
  • 脑机接口SSVEP经典算法 TRCA任务相关成分分析 matlab实战
  • 05类加载机制篇(D6_方法调用和方法执行)
  • QSFP(Quad Small Form-factor Pluggable)详解
  • DeepSeek赋能Power BI:开启智能化数据分析新时代
  • uniapp 常用 UI 组件库
  • 华为hcia——Datacom实验指南——配置手工模式以太网链路聚合
  • 蓝桥云客 求和
  • 有了域名之后怎么做网站/全球搜索网站排名
  • 外贸电商做俄罗斯市场网站/竞价推广工作内容
  • 百度网站提交入口/优化公司排名
  • lamp 网站建设论文/制作自己的网页
  • 郑州英文网站建设/长沙seo网站排名
  • 东莞长安网站设计公司/营销网站建设流程