使用Quarz2D 绘制进度条

一直觉得iphone系统自带的进度条有点简陋,由于项目的实际需要,我参考了一些资料,自己绘制了一个进度条,主要使用Quarz2D来实现的。  绘制矩形,填充内部颜色,描边,然后从左侧往右侧逐渐改变填充颜色,最后的效果就是一个动态的进度条实现了。

首先是头文件:CustomProgressView.h

 

 

//  Created by suruqiang on 8/4/10.
//  Copyright 2010 __MyCompanyName__. All rights reserved.
//

#import <UIKit/UIKit.h>


@interface CustomProgressView : UIView {

	float progress;
}

@property(assign, nonatomic) float progress;
-(id) init;
//-(void)drawRect:(CGRect)_rect borderRadius:(CGFloat)_rad borderWidth:(CGFloat)_thickness barRadius:(CGFloat)_barRadius barInsert:(CGFloat)_barInsert;
-(void) drawRect:(CGRect)rect borderRadius:(CGFloat)rad borderWidth:(CGFloat)thickness barRadius:(CGFloat)barRadius barInset:(CGFloat)barInset;
@end

 

 

 

CustomProgressView.m文件实现代码:

 

//  Created by suruiqiang on 8/4/10.
//  Copyright 2010 __MyCompanyName__. All rights reserved.
//

#import "CustomProgressView.h"


@implementation CustomProgressView
@synthesize progress;



-(id) init
{
	CGRect rect = CGRectMake(0, 0, 210, 20);
	//if(![super initWithFrame:rect])
	//	return nil;
	[super initWithFrame:rect];
	progress = 0;
	self.backgroundColor = [UIColor clearColor];
	
	return self;
}


-(void)setProgress:(float)_progress
{
	_progress = MIN(MAX(0,_progress),1);
	if(_progress==progress)
		return;
	progress = _progress;
	
	[self setNeedsDisplay];
}



- (void) drawRect:(CGRect)rect
{
	[self drawRect:rect borderRadius:8. borderWidth:2. barRadius:5. barInset:3.];
}


-(void) drawRect:(CGRect)rect borderRadius:(CGFloat)rad borderWidth:(CGFloat)thickness barRadius:(CGFloat)barRadius barInset:(CGFloat)barInset{
	//draw the outside rectangle of custom progressview
	CGContextRef context = UIGraphicsGetCurrentContext();
	CGRect rrect = CGRectInset(rect,thickness, thickness);
	CGFloat radius = rad;
	CGFloat minx = CGRectGetMinX(rrect), midx = CGRectGetMidX(rrect), maxx = CGRectGetMaxX(rrect);
	CGFloat miny = CGRectGetMinY(rrect), midy = CGRectGetMidY(rrect), maxy = CGRectGetMaxY(rrect);
	CGContextMoveToPoint(context, minx, midy);
	CGContextAddArcToPoint(context, minx, miny, midx, miny, radius);
	CGContextAddArcToPoint(context, maxx, miny, maxx, midy, radius);
	CGContextAddArcToPoint(context, maxx, maxy, midx, maxy, radius);
	CGContextAddArcToPoint(context, minx, maxy, minx, midy, radius);
	CGContextClosePath(context);
	CGContextSetRGBStrokeColor(context, 0, 1, 1, 1);
	//CGContextSetRGBFillColor(context,1, 1, 1, 1);
	CGContextSetLineWidth(context, thickness);
	CGContextDrawPath(context, kCGPathStroke);

	radius = barRadius;
	
	rrect = CGRectInset(rrect, barInset, barInset);
	rrect.size.width = rrect.size.width * self.progress;
	minx = CGRectGetMinX(rrect), midx = CGRectGetMidX(rrect), maxx = CGRectGetMaxX(rrect);
	miny = CGRectGetMinY(rrect), midy = CGRectGetMidY(rrect), maxy = CGRectGetMaxY(rrect);
	CGContextMoveToPoint(context, minx, midy);
	CGContextAddArcToPoint(context, minx, miny, midx, miny, radius);
	CGContextAddArcToPoint(context, maxx, miny, maxx, midy, radius);
	CGContextAddArcToPoint(context, maxx, maxy, midx, maxy, radius);
	CGContextAddArcToPoint(context, minx, maxy, minx, midy, radius);
	CGContextClosePath(context);
	CGContextSetRGBFillColor(context,1, 0, 1, 1);
	CGContextDrawPath(context, kCGPathFill);
	
}

- (void)viewDidUnload {
	// Release any retained subviews of the main view.
	// e.g. self.myOutlet = nil;
}


- (void)dealloc {
    [super dealloc];
}


@end

 

 

 

调用出的代码如下:

 

- (void)viewDidLoad {
    [super viewDidLoad];
//[self.view addSubview:[self progressBar]];
	progressBar = [[CustomProgressView alloc] init];
	progressBar.center = CGPointMake(160.0f, 160.0f);
	[progressBar setProgress:0.01];
	[self.view addSubview:progressBar];
	
	
	time = 0;
	timer = [[NSTimer timerWithTimeInterval:0.02 target:self selector:@selector(timer) userInfo:nil repeats:YES] retain];
	[[NSRunLoop currentRunLoop] addTimer:timer forMode:NSDefaultRunLoopMode];


}


-(void)timer
{
	self.progressBar.progress = time / 100.0;
	
	time++;
	if(time > 130) time = -30;
	return;
}

由于本人只是潦草的绘制了一番,没有任何美工元素,实际项目中需要对颜色等进行设置优化。


 

posted @ 2010-10-19 23:18  苏瑞强  阅读(881)  评论(0编辑  收藏  举报