html 滑动条 双向滑动,iOS实现双向滑动条效果

最近做项目,碰到一种双向滑动条,自己实现了一下,随便写一下思路,方便以后开发,避免重复写代码,以后粘贴就行了。封装了一下,代码如下:

#import

typedef NSString* (^HLDoubleSlideViewSwitchStrBock)(CGFloat count);

@interface HLDoubleSlideView : UIView

@property(nonatomic,assign)CGFloat maxValue;

@property(nonatomic,assign)CGFloat minValue;

@property(nonatomic,assign)CGFloat currentLeftValue;

@property(nonatomic,assign)CGFloat currentRightValue;

//格式化显示文本

@property(nonatomic,copy)HLDoubleSlideViewSwitchStrBock block;

@end

源文件如下:

#import "HLDoubleSlideView.h"

#import "UIView+Add.h"

@interface HLDoubleSlideView ()

@property(nonatomic,strong)UIImageView *leftImageView;

@property(nonatomic,strong)UIImageView *rightImageView;

@property(nonatomic,strong)UILabel *leftLabel;

@property(nonatomic,strong)UILabel *rightLabel;

@property(nonatomic,strong)UIButton *leftBtn;

@property(nonatomic,strong)UIButton *rightBtn;

@property(nonatomic,assign)CGFloat leftBtnOrgx;

@property(nonatomic,assign)CGFloat rightBtnOrgx;

@end

@implementation HLDoubleSlideView

-(id)init

{

if (self = [super init]) {

[self setupUI];

}

return self;

}

-(void)setupUI

{

_leftImageView = [[UIImageView alloc] init];

_leftImageView.image = [UIImage imageNamed:@"progressImage"];

_leftImageView.frame = CGRectMake(0, 5, 60, 40);

[self addSubview:_leftImageView];

_leftLabel = [[UILabel alloc] initWithFrame:_leftImageView.bounds];

_leftLabel.backgroundColor = [UIColor clearColor];

_leftLabel.font = [UIFont systemFontOfSize:13];

_leftLabel.textAlignment = NSTextAlignmentCenter;

_leftLabel.textColor = [UIColor whiteColor];

[_leftImageView addSubview:_leftLabel];

_rightImageView = [[UIImageView alloc] init];

_rightImageView.image = [UIImage imageNamed:@"progressImage"];

_rightImageView.frame = CGRectMake(0, 5, 60, 40);

[self addSubview:_rightImageView];

_rightLabel = [[UILabel alloc] initWithFrame:_rightImageView.bounds];

_rightLabel.backgroundColor = [UIColor clearColor];

_rightLabel.font = [UIFont systemFontOfSize:13];

_rightLabel.textAlignment = NSTextAlignmentCenter;

_rightLabel.textColor = [UIColor whiteColor];

[_rightImageView addSubview:_rightLabel];

_leftBtn = [UIButton buttonWithType:UIButtonTypeCustom];

_leftBtn.frame = CGRectMake(0, 50, 20,20);

_leftBtn.backgroundColor = [UIColor blueColor];

_leftBtn.layer.cornerRadius = 10;

[self addSubview:_leftBtn];

UIPanGestureRecognizer *panGesture = [[UIPanGestureRecognizer alloc] initWithTarget:self action:@selector(tapGestureAction:)];

panGesture.delegate = self;

[_leftBtn addGestureRecognizer:panGesture];

_leftImageView.centerX = _leftBtn.centerX;

_rightBtn = [UIButton buttonWithType:UIButtonTypeCustom];

_rightBtn.backgroundColor = [UIColor blueColor];

_rightBtn.frame = CGRectMake(240, 50, 20, 20);

_rightBtn.layer.cornerRadius = 10;

panGesture = [[UIPanGestureRecognizer alloc] initWithTarget:self action:@selector(tapGestureAction:)];

panGesture.delegate = self;

[_rightBtn addGestureRecognizer:panGesture];

_rightImageView.centerX = _rightBtn.centerX;

[self addSubview:_rightBtn];

}

- (BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer

{

return YES;

}

-(UIView*)hitTest:(CGPoint)point withEvent:(UIEvent *)event

{

NSLog(@"doubleView hitTest");

return [super hitTest:point withEvent:event];

}

-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event

{

NSLog(@"began");

[super touchesBegan:touches withEvent:event];

}

-(void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event

{

NSLog(@"move");

[super touchesMoved:touches withEvent:event];

}

-(void)layoutSubviews

{

CGFloat centenX = (_currentLeftValue - _minValue) * (self.bounds.size.width - 20)/(_maxValue - _minValue) + 10;

_leftBtn.centerX = centenX;

if (_currentLeftValue != 0) {

CGFloat centenX = (_currentRightValue - _minValue) * (self.bounds.size.width - 20) / (_maxValue - _minValue) + 10;

_rightBtn.centerX = centenX;

}

else

{

_rightBtn.centerX = self.bounds.size.width - 10;

}

_leftImageView.centerX = _leftBtn.centerX;

_rightImageView.centerX = _rightBtn.centerX;

if (_block) {

_leftLabel.text = _block(_currentLeftValue);

_rightLabel.text = _block(_currentRightValue);

}

}

-(void)tapGestureAction:(UIPanGestureRecognizer*)panGesture

{

UIView *vw = panGesture.view;

CGPoint transPoint = [panGesture translationInView:self];

NSLog(@"x:%lf,y:%lf",transPoint.x,transPoint.y);

switch (panGesture.state) {

case UIGestureRecognizerStateBegan:

{

if ([vw isEqual:_leftBtn])

{

_leftBtnOrgx = _leftBtn.orgX;

NSLog(@"拖拽左边按钮");

}

else if([vw isEqual:_rightBtn])

{

_rightBtnOrgx = _rightBtn.orgX;

NSLog(@"拖拽右边按钮");

}

}

break;

case UIGestureRecognizerStateChanged:

{

if ([vw isEqual:_leftBtn])

{

CGFloat orginX = _leftBtn.orgX;

_leftBtn.orgX = _leftBtnOrgx + transPoint.x;

if (_leftBtn.orgX < 0) {

_leftBtn.orgX = 0;

}

else if(_leftBtn.orgX >= _rightBtn.orgX - 20)

{

_leftBtn.orgX = orginX;

}

_leftImageView.centerX = _leftBtn.centerX;

}

else if([vw isEqual:_rightBtn])

{

CGFloat orginX = _rightBtn.orgX;

_rightBtn.orgX = _rightBtnOrgx + transPoint.x;

if (_rightBtn.orgX >= self.bounds.size.width - 20) {

_rightBtn.orgX = self.bounds.size.width - 20;

}

else if(_rightBtn.orgX <= _leftBtn.orgX + 20)

{

_rightBtn.orgX = orginX;

}

_rightImageView.centerX = _rightBtn.centerX;

}

}

break;

case UIGestureRecognizerStateEnded:

{

}

break;

default:

break;

}

_currentLeftValue = _minValue + (_maxValue - _minValue) * ((_leftBtn.centerX - 10) / (self.bounds.size.width - 20));

_currentRightValue = _minValue + (_maxValue - _minValue) * ((_rightBtn.centerX - 10) / (self.bounds.size.width - 20));

if (_block) {

_leftLabel.text = _block(_currentLeftValue);

_rightLabel.text = _block(_currentRightValue);

}

NSLog(@"leftValue:%lf,rightValue:%lf",_currentLeftValue,_currentRightValue);

[self setNeedsDisplay];

}

-(void)setCurrentLeftValue:(CGFloat)currentLeftValue

{

_currentLeftValue = currentLeftValue;

CGFloat centenX = (currentLeftValue - _minValue) * (self.bounds.size.width - 20)/(_maxValue - _minValue) + 10;

_leftBtn.centerX = centenX;

[self setNeedsDisplay];

}

-(void)setCurrentRightValue:(CGFloat)currentRightValue

{

_currentRightValue = currentRightValue;

CGFloat centenX = (_currentRightValue - _minValue) * (self.bounds.size.width - 20) / (_maxValue - _minValue) + 10;

_rightBtn.centerX = centenX;

[self setNeedsDisplay];

}

-(void)drawRect:(CGRect)rect

{

CGContextRef context = UIGraphicsGetCurrentContext();

CGContextSetLineCap(context, kCGLineCapRound);

CGContextSetLineWidth(context, 3);

[[UIColor grayColor] setStroke];

CGContextMoveToPoint(context, 0, 60);

CGContextAddLineToPoint(context, self.bounds.size.width, 60);

CGContextStrokePath(context);

[[UIColor redColor] setStroke];

CGContextMoveToPoint(context, _leftBtn.orgX + 10, 60);

CGContextAddLineToPoint(context, _rightBtn.orgX,60);

CGContextStrokePath(context);

}

@end

使用如下:

HLDoubleSlideView *doubleSlideView = [[HLDoubleSlideView alloc] init];

doubleSlideView.backgroundColor = [UIColor whiteColor];//HLColor(244, 244, 244);

doubleSlideView.minValue = 1000;

doubleSlideView.maxValue = 10000;

doubleSlideView.block = ^NSString*(CGFloat count)

{

return [NSString stringWithFormat:@"%.0f元",count];

};

[self.view addSubview:doubleSlideView];

doubleSlideView.frame = CGRectMake(60, 64, 250, 80);

doubleSlideView.currentLeftValue = 1200;

doubleSlideView.currentRightValue = 10000;

运行结果如下:

29df87e81e537fc3495fb0703e53357f.gif

以上就是本文的全部内容,希望对大家的学习有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【优质项目推荐】 1、项目代码均经过严格本地测试,运行OK,确保功能稳定后才上传平台。可放心下载并立即投入使用,若遇到任何使用问题,随时欢迎私信反馈与沟通,博主会第一时间回复。 2、项目适用于计算机相关专业(如计科、信息安全、数据科学、人工智能、通信、物联网、自动化、电子信息等)的在校学生、专业教师,或企业员工,小白入门等都适用。 3、该项目不仅具有很高的学习借鉴价值,对于初学者来说,也是入门进阶的绝佳选择;当然也可以直接用于 毕设、课设、期末大作业或项目初期立项演示等。 3、开放创新:如果您有一定基础,且热爱探索钻研,可以在此代码基础上二次开发,进行修改、扩展,创造出属于自己的独特应用。 欢迎下载使用优质资源!欢迎借鉴使用,并欢迎学习交流,共同探索编程的无穷魅力! 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值