From 5cc676ce521277c6b75a078d25823bea023cfaf0 Mon Sep 17 00:00:00 2001 From: huhuanming Date: Fri, 11 Oct 2024 23:51:55 +0800 Subject: [PATCH] feat: support border-radius on cursor --- src/PageContentView.tsx | 8 ++++++-- src/PageHeaderCursor.tsx | 12 ++++++------ src/PageHeaderView.tsx | 29 ++++++++++++++++++----------- 3 files changed, 30 insertions(+), 19 deletions(-) diff --git a/src/PageContentView.tsx b/src/PageContentView.tsx index 62188f3..2c48263 100644 --- a/src/PageContentView.tsx +++ b/src/PageContentView.tsx @@ -64,7 +64,7 @@ export default class PageContentView extends Component { }, ], { - useNativeDriver: true, + useNativeDriver: false, } ); private scrollView: RefObject | null = React.createRef(); @@ -91,7 +91,11 @@ export default class PageContentView extends Component { }, } = event; const reloadWidth = PixelRatio.roundToNearestPixel(width); - if (reloadWidth !== this.state.scrollViewWidth && reloadWidth > 0) { + if ( + reloadWidth !== this.state.scrollViewWidth && + reloadWidth > 0 && + (this?.props?.data?.length ?? 0) > 0 + ) { this._scrollViewWidthValue.setValue(reloadWidth); this.setState({ scrollViewWidth: reloadWidth }, () => { this?.scrollView?.current?.reloadScrollContainerWidth?.(reloadWidth); diff --git a/src/PageHeaderCursor.tsx b/src/PageHeaderCursor.tsx index e2b689d..d58eb7b 100644 --- a/src/PageHeaderCursor.tsx +++ b/src/PageHeaderCursor.tsx @@ -78,7 +78,7 @@ export default class PageHeaderCursor extends Component { const width = item.width - left - right; return isWidth ? (width * Number(percentWidth ?? 100)) / 100 - : item.x + width / 2.0 + left; + : item.x + left; } } else { return 0; @@ -113,11 +113,11 @@ export default class PageHeaderCursor extends Component { override render() { const fixCursorWidth = this._findFixCursorWidth(); const translateX = this._reloadPageIndexValue(false); - const scaleX = this._reloadPageIndexValue(true); + const widthX = this._reloadPageIndexValue(true); const containerStyle: Animated.WithAnimatedObject = { - transform: [{ translateX }, fixCursorWidth ? { scale: 1 } : { scaleX }], - width: fixCursorWidth ?? 1, + transform: [{ translateX }], + width: fixCursorWidth ?? widthX, position: 'absolute', top: 0, bottom: 0, @@ -127,7 +127,7 @@ export default class PageHeaderCursor extends Component { const contentStyle = [ this.props.cursorStyle, - { left: null, right: null, width: fixCursorWidth ?? 1 }, + { left: null, right: null, width: fixCursorWidth ?? widthX }, ]; return ( @@ -149,7 +149,7 @@ export default class PageHeaderCursor extends Component { {this.props.renderCursor ? ( this.props.renderCursor() ) : ( - + )} diff --git a/src/PageHeaderView.tsx b/src/PageHeaderView.tsx index e700319..541d0c3 100644 --- a/src/PageHeaderView.tsx +++ b/src/PageHeaderView.tsx @@ -2,7 +2,6 @@ import React, { Component } from 'react'; import type { RefObject } from 'react'; import { View, - StyleSheet, Pressable, ScrollView, Animated, @@ -34,24 +33,28 @@ interface PageHeaderViewProps extends ScrollViewProps { scrollContainerStyle?: object; contentContainerStyle?: object; containerStyle?: object; + itemContainerSelectedStyle?: object; } export default class PageHeaderView extends Component { private scrollPageIndex = this.props.initialScrollIndex ?? 0; - private scrollPageIndexValue = new Animated.Value(this.scrollPageIndex); + private scrollPageIndexValue = new Animated.Value(this.scrollPageIndex, { + useNativeDriver: false, + }); private nextScrollPageIndex = -1; private shouldHandlerAnimationValue = true; private itemConfigList = this.props.data.map((_: any) => ({ _animtedEnabledValue: new Animated.Value(1), _containerRef: React.createRef(), })); - private itemContainerStyle = () => + private itemContainerStyle = (index?: number) => ({ height: '100%', flexDirection: 'row', alignItems: 'center', justifyContent: 'center', ...this.props.itemContainerStyle, + ...(this.props.itemContainerSelectedStyle) } as { flex?: number } & object); private itemTitleNormalStyle: () => { fontSize: number; @@ -80,6 +83,7 @@ export default class PageHeaderView extends Component { }); private scrollView: RefObject = React.createRef(); private cursor: RefObject = React.createRef(); + private scrollViewWidth = 0; static defaultProps: PageHeaderViewProps = { data: [], @@ -128,7 +132,7 @@ export default class PageHeaderView extends Component { const itemLayout = this?.cursor?.current?.state ?.itemContainerLayoutList?.[newPageIndex] ?? { x: 0, width: 0 }; this?.scrollView?.current?.scrollTo({ - x: itemLayout.x - itemLayout.width, + x: itemLayout.x + itemLayout.width / 2.0 - this.scrollViewWidth / 2.0, }); this.scrollPageIndex = newPageIndex; } @@ -217,7 +221,7 @@ export default class PageHeaderView extends Component { this.scrollPageIndexValue, index, this.props.selectedPageIndexDuration, - true + false ); } this.props.onSelectedPageIndex?.(index); @@ -232,7 +236,7 @@ export default class PageHeaderView extends Component { this._itemDidTouch(item, index)} > {content} @@ -265,8 +269,9 @@ export default class PageHeaderView extends Component { } override render() { + const { style, ...restProps } = this.props; return ( - + { this?.cursor?.current?.reloadItemListContainerLayout( @@ -275,16 +280,18 @@ export default class PageHeaderView extends Component { ); this?.props?.onContentSizeChange?.(width, height); }} - {...this.props} + onLayout={(event) => { + this.scrollViewWidth = event.nativeEvent.layout.width; + this?.props?.onLayout?.(event); + }} + style={this.props.containerStyle} + {...restProps} contentContainerStyle={[ { width: this.itemContainerStyle()?.flex ? '100%' : null }, this.props.scrollContainerStyle, ]} ref={this.scrollView} > -