zoukankan      html  css  js  c++  java
  • iOS 自定义进度条

    自定义条形进度条(iOS)

    ViewController.m文件

    #import "ViewController.h"
    @interface ViewController ()
    @property(strong,nonatomic)UIButton *btnBegin;
    @property(strong,nonatomic)UIButton *btnStop;
    @property(strong,nonatomic)UIButton *btnResert;
    @property(strong,nonatomic)UITextField *shangx;
    @property(strong,nonatomic)UIproessMy *proess;
    @end
    @implementation ViewController
    
    - (void)viewDidLoad {
    
        
        self.proess=[[UIproessMy alloc]initWithFrame:CGRectMake(80, 100, 250, 20)];
        self.proess.backgroundColor=[UIColor clearColor];
        [self.view addSubview:self.proess];
        //设置值 百分比
        self.proess.index=80;
        [self setBtn];
    }
    //生成按钮
    -(void)setBtn{
        
        self.btnBegin=[[UIButton alloc]initWithFrame:CGRectMake(100, 500, 200, 50)];
        self.btnBegin.backgroundColor=[UIColor colorWithRed:0.294 green:1.000 blue:0.368 alpha:1.000];
        self.btnBegin.layer.cornerRadius=25;
        self.btnBegin.layer.masksToBounds=YES;
        [self.btnBegin setTitle:@"开始" forState:UIControlStateNormal];
        [self.btnBegin addTarget:self action:@selector(chang) forControlEvents:UIControlEventTouchUpInside];
        [self.view addSubview:self.btnBegin];
        
        self.btnStop=[[UIButton alloc]initWithFrame:CGRectMake(100, 600, 200, 50)];
        self.btnStop.backgroundColor=[UIColor colorWithRed:0.294 green:1.000 blue:0.368 alpha:1.000];
        self.btnStop.layer.cornerRadius=25;
        self.btnStop.layer.masksToBounds=YES;
        [self.btnStop setTitle:@"停止" forState:UIControlStateNormal];
        [self.btnStop addTarget:self action:@selector(stopBtn) forControlEvents:UIControlEventTouchUpInside];
        [self.view addSubview:self.btnStop];
        
        
        self.btnResert=[[UIButton alloc]initWithFrame:CGRectMake(100, 400, 200, 50)];
        self.btnResert.backgroundColor=[UIColor colorWithRed:0.294 green:1.000 blue:0.368 alpha:1.000];
        self.btnResert.layer.cornerRadius=25;
        self.btnResert.layer.masksToBounds=YES;
        [self.btnResert setTitle:@"重置" forState:UIControlStateNormal];
        [self.btnResert addTarget:self action:@selector(Resert) forControlEvents:UIControlEventTouchUpInside];
        [self.view addSubview:self.btnResert];
    
    }
    //停止
    -(void)stopBtn{
        [self.proess stop];
    }
    //开始
    -(void)chang{
        [self.proess begin];
    }
    //重置
    -(void)Resert{
        [self.proess resert];
    }
    - (void)didReceiveMemoryWarning {
        [super didReceiveMemoryWarning];
      
    }
    
    @end

    自定义类

    UIproessMy.h

    #import <UIKit/UIKit.h>
    
    @interface UIproessMy : UIView
    @property(strong,nonatomic)UIView *aView;
    @property(strong,nonatomic)UIView *UIProess;
    @property(strong,nonatomic)UILabel *label;
    @property(strong,nonatomic)NSTimer *time;
    @property(assign,nonatomic)float index;
    -(void)change;
    -(void)begin;
    -(void)stop;
    -(void)resert;
    @end

    UIproessMy.m文件

    #import "UIproessMy.h"
    
    @implementation UIproessMy
    - (instancetype)initWithFrame:(CGRect)frame
    {
        self = [super initWithFrame:frame];
        if (self) {
            //初始化
            self.aView=[[UIView alloc]initWithFrame:CGRectMake(0, 0, 250, 20)];
            self.aView.backgroundColor=[UIColor colorWithRed:0.841 green:0.848 blue:0.773 alpha:1.000];
            self.UIProess=[[UIView alloc]initWithFrame:CGRectMake(0, 1,0, 18)];
            self.aView.layer.cornerRadius=10;
            self.aView.layer.masksToBounds=YES;
            self.UIProess.layer.cornerRadius=10;
            self.UIProess.layer.masksToBounds=YES;
            self.UIProess.backgroundColor=[UIColor colorWithRed:0.327 green:0.816 blue:0.075 alpha:1.000];
            
            self.label=[[UILabel alloc]initWithFrame:CGRectMake(0, 50, 250, 200)];
            self.label.backgroundColor=[UIColor colorWithRed:0.457 green:0.889 blue:1.000 alpha:1.000];
            self.label.layer.cornerRadius=100;
            self.label.layer.masksToBounds=YES;
            self.label.textAlignment=NSTextAlignmentCenter;
            self.label.font=[UIFont boldSystemFontOfSize:50];
            self.label.text=[NSString stringWithFormat:@"0%%"];
            [self.aView addSubview:self.UIProess];
            [self addSubview:self.aView];
            [self addSubview:self.label];
           
          
        }
        return self;
    }
    //开始
    -(void)begin{
        if (self.UIProess.frame.size.width<250*(self.index)*0.01) {
            self.time=[NSTimer scheduledTimerWithTimeInterval:0.01 target:self selector:@selector(change) userInfo:nil repeats:YES];
            [[NSRunLoop mainRunLoop] addTimer:self.time forMode:NSDefaultRunLoopMode];
        }else{
             [self.time invalidate];
        }
        
    }
    //重置
    -(void)resert{
        [self initWithFrame:CGRectMake(0, 1, 0, 18)];
        self.label.text=[NSString stringWithFormat:@"0%%"];
        [self.time setFireDate:[NSDate distantFuture]];
    
    }
    //停止
    -(void)stop{
        int a=1;
        if (a==1) {
            [self.time setFireDate:[NSDate distantFuture]];
            a=0;
        }else{
            [self.time setFireDate:[NSDate date]];
            a=1;
        }
      }
    //变化 调用定时器
    
    -(void)change{
        CGRect changeFrame=self.UIProess.frame;
        changeFrame.size.width+=0.25;
        self.UIProess.frame=changeFrame;
        if (self.UIProess.frame.size.width>=250*(self.index)*0.01) {
            [self.time invalidate];
    //        [self initWithFrame:self.UIProess.frame];
        }
        self.label.text=[NSString stringWithFormat:@"%.1f%%",self.UIProess.frame.size.width/250*100];
    }
    @end

    效果

  • 相关阅读:
    找出文件1中有而文件2中没有的数据
    读取文件内容返回List<String>类型
    【概率论与数理统计】小结6
    【概率论与数理统计】小结5
    【概率论与数理统计】小结4
    【概率论与数理统计】小结3
    【概率论与数理统计】小结2
    记Angular与Django REST框架的一次合作(2):前端组件化——Angular
    记Angular与Django REST框架的一次合作(1):分离 or 不分离,it's the question
    【概率论与数理统计】小结1
  • 原文地址:https://www.cnblogs.com/qianLL/p/5263675.html
Copyright © 2011-2022 走看看