如何在iPhone 显示一个 星级评分
http://blog.csdn.net/fanjunxi1990/article/details/8663914
由于项目需求,需要做一个列表,里面有各个商品的评分,就是app store里面所有app的星级评分
下面是DisplayStarView.h
- //
- // DisplayStarView.h
- // testExpress
- //
- // Created by Juncy_Fan on 13-3-12.
- // Copyright (c) 2013年 Juncy_Fan. All rights reserved.
- //
- #import <Foundation/Foundation.h>
- @interface DisplayStarView : UIView
- {
- CGFloat _starSize; /* 根据字体大小来确定星星的大小 */
- NSInteger _maxStar; /* 总共的长度 */
- NSInteger _showStar; //需要显示的星星的长度
- UIColor *_emptyColor; //未点亮时候的颜色
- UIColor *_fullColor; //点亮的星星的颜色
- }
- @property (nonatomic, assign) CGFloat starSize;
- @property (nonatomic, assign) NSInteger maxStar;
- @property (nonatomic, assign) NSInteger showStar;
- @property (nonatomic, retain) UIColor *emptyColor;
- @property (nonatomic, retain) UIColor *fullColor;
- @end
DisplayStarView.m如下
- //
- // DisplayStarView.m
- // testExpress
- //
- // Created by Juncy_Fan on 13-3-12.
- // Copyright (c) 2013年 Juncy_Fan. All rights reserved.
- //
- #import "DisplayStarView.h"
- @implementation DisplayStarView
- @synthesize starSize = _starSize;
- @synthesize maxStar = _maxStar;
- @synthesize showStar = _showStar;
- @synthesize emptyColor = _emptyColor;
- @synthesize fullColor = _fullColor;
- - (id)initWithFrame:(CGRect)frame
- {
- self = [super initWithFrame:frame];
- if (self)
- {
- self.backgroundColor = [UIColor clearColor];
- //默认的星星的大小是 13.0f
- self.starSize = 13.0f;
- //未点亮时的颜色是 灰色的
- self.emptyColor = [UIColor colorWithRed:167.0f / 255.0f green:167.0f / 255.0f blue:167.0f / 255.0f alpha:1.0f];
- //点亮时的颜色是 亮黄色的
- self.fullColor = [UIColor colorWithRed:255.0f / 255.0f green:121.0f / 255.0f blue:22.0f / 255.0f alpha:1.0f];
- //默认的长度设置为100
- self.maxStar = 100;
- }
- return self;
- }
- //重绘视图
- - (void)drawRect:(CGRect)rect
- {
- // Drawing code
- CGContextRef context = UIGraphicsGetCurrentContext();
- NSString* stars = @"★★★★★";
- rect = self.bounds;
- UIFont *font = [UIFont boldSystemFontOfSize:_starSize];
- CGSize starSize = [stars sizeWithFont:font];
- rect.size=starSize;
- [_emptyColor set];
- [stars drawInRect:rect withFont:font];
- CGRect clip = rect;
- clip.size.width = clip.size.width * _showStar / _maxStar;
- CGContextClipToRect(context,clip);
- [_fullColor set];
- [stars drawInRect:rect withFont:font];
- }
- - (void)dealloc
- {
- [_emptyColor release];
- [_fullColor release];
- [super dealloc];
- }
- @end
需要怎么去使用呢?很简单,值需要知道评分是多少就OK啦,比如
- //评论是4.2分的
- DisplayStarView *sv = [[DisplayStarView alloc]initWithFrame:CGRectMake(90, 90, 200, 40)];
- [self.view addSubview:sv];
- sv.showStar = 4.2*20;
- [sv release];
- //评论是2.5分的
- DisplayStarView *sv1 = [[DisplayStarView alloc]initWithFrame:CGRectMake(90, 90+40, 200, 40)];
- [self.view addSubview:sv1];
- sv1.showStar = 2.5 * 20;
- [sv1 release];
- //评论是4.8分的
- DisplayStarView *sv2 = [[DisplayStarView alloc]initWithFrame:CGRectMake(90, 90+40+40, 200, 40)];
- [self.view addSubview:sv2];
- sv2.showStar = 4.8 * 20;
- [sv2 release];
运行结果如图所示:
如何在iPhone 显示一个 星级评分的更多相关文章
- 干货之运用CALayer创建星级评分组件(五角星)
本篇记录星级评分组件的创建过程以及CALayer的运用. 为了实现一个星级评分的组件,使用了CALayer,涉及到mask.CGPathRef.UIBezierPath.动画和一个计算多角星关键节点的 ...
- Angular 星级评分组件
一.需求演变及描述: 1. 有一个“客户对公司的总体评价”的字段(evalutation).字段为枚举类型,0-5,对应关系为:0-暂无评价,1-很差,2-差,3-一般,4-好,5-很好 2. 后来需 ...
- js 实现星级评分
最近的项目中有一个星级评分的需求, 自己就写了一下, 由于可能一个页面要用到多个,就采用了面向对象的写法. 用到的png图片也放到这里. js要用到jquery. css: .sr-star{ ...
- js实现星级评分之方法一
利用一个星级评分的小案例,来逐步封装js星级评分插件. 从最基础的js知识,通过一个小的demo,逐步学习js的面向对象知识. 从浅到深,逐步递进. 图片素材 <!DOCTYPE html> ...
- 星级评分进度条(RatingBar)
星级评分进度条(RatingBar):(主要用于评价等方面) 常用的xml属性; android:isIndicator:RatingBar是否是一个指示器(用户无法进行更改) android:num ...
- 用css制作星级评分
Step 1: XHTML <ul class="star-rating"> <li><a href="#" titl ...
- Android 拖动条/滑动条控件、星级评分控件
ProgressBar有2个子控件: SeekBar 拖动条控件 RatingBar 星级评分控件 1.拖动条控件 <SeekBar android:layout_width=" ...
- 原生JS实现-星级评分系统
今天我又写了个很酷的实例:星级评分系统(可自定义星星个数.显示信息) sufuStar.star();使用默认值5个星星,默认信息 var msg = [........]; sufuStar.sta ...
- javascript星级评分(多个)
JS打多个类型星级评分: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http: ...
随机推荐
- 事务一致性理解 事务ACID特性的完全解答
A 原子性 事务管理者多个小操作,他们同时完成或者同时不完成就是原子性 C 一致性 一致性,是一个很相对的,很主观的概念, 一致性 描述的是 事务 从一个一致的状态变成 另一个一致的状态. 一致性需 ...
- 【DM642学习笔记五】FVID驱动模型 API函数
1.FVID_control 作用:发送一个控制命令到mini_driver 语法: status = FVID_control(fvidChan, cmd, args); 参数: FVID_Hand ...
- Spring Cloud Consul综合整理
该项目通过自动配置和Spring环境以及其他Spring编程模型习惯用法提供了Spring Boot应用程序的Consul集成. 通过一些简单的注释,您可以快速启用和配置应用程序内的通用模式,并使用基 ...
- css3新特性概览
一.特性 1.强大的选择器 2.半透明度效果的实现 3.多栏布局 4.多背景图 css3允许背景属性设置多个属性值,如:background-image,background-repeat,backg ...
- 访问hbase的内部大致流程
hbase 访问表过程.Client(客户端)----->访问ZK(拿到meta表的region位置)----->访问meta 表的region------>拿到user表的regi ...
- springboot实现定时任务的方式
springboot实现定时任务的方式 a Timer:这是java自带的java.util.Timer类,这个类允许你调度一个java.util.TimerTask任务.使用这种方式可以让你的程 ...
- python numpy.shape 和 numpy.reshape函数
导入numpy模块 from numpy import * import numpy as np ############################################### ...
- Nonsense Time
Nonsense Time 时间限制: 10 Sec 内存限制: 128 MB 题目描述 You a given a permutation p1,p2,…,pn of size n. Initia ...
- 干货来了!2019阿里云合作伙伴峰会SaaS加速器专场回顾合集:嘉宾分享、深度解读
2019年7月26日,在上海举办的阿里云合作伙伴峰会上,阿里云正式发布SaaS生态战略,计划用阿里云的品牌.渠道.资本.方法论.技术加持伙伴,成就亿级营收独角兽. 该生态战略计划招募10家一级SaaS ...
- c++设计模式:访问者模式(visitor模式)
1.c语言中回调基本都过函数指针来完成.c++中主要通过接口的方式完成回调.而visitor就是实现接口回调的一种方式. 1.首先定义个一个接口visitor类, class classVisitor ...