gpt4 book ai didi

ios - 步长不均匀的 UISlider。

转载 作者:可可西里 更新时间:2023-11-01 04:51:55 25 4
gpt4 key购买 nike

我需要实现如下图所示的 slider 控件

slider 将具有不均匀的长度步长。每当用户滑动 slider 时, slider 只会停在接近当前范围的步长之一。

但真正的挑战是 UISlider 在自定义点(范围)处带有点,这些点将在最初提供。

谁能帮我实现这个功能。

最佳答案

我认为你最好不要尝试将 UISlider 改造成这个配置

如果这是我的问题,我会构建一个像这样结构的自定义 View

 DKCustomSliderView
-> UIImageView (subview for slider head)

它实现了这样的接口(interface)。

@interface DKCustomSliderView : UIView

-(void)setStopPoints:(NSArray *)stopPoints; //array of NSNumbers between 0-1 which define indents
-(void)setSliderHeadImage:(UIImage *)sliderHeadImage; //image to use as slider head
-(void)setIndentImage:(UIImage *)indentImage; //image to use as indent marker
-(void)setTrackImage:(UIImage *)trackImage; //stretchy image to use on track

@end

我会在 slider ImageView 上跟踪平移手势。

-(void)handlePanGesture:(UIPanGestureRecogniser *)pgr {

if(pgr.state == UIGestureRecogniserStateChanged) {

//am i near an indent? , if so lock me here and be slightly sticky.

}
}

DKCustomSliderView 的绘制矩形看起来有点像这样。

-(void)drawRect:(CGRect)dirtyRect {

CGRect bounds = self.bounds;

// 1. draw track across width

for(NSNumber *marker in self.stopPoints) {

//draw a instance of self.indentImage at ([marker floatValue]/bounds.size.width)

}

}

关于ios - 步长不均匀的 UISlider。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22476025/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com