如何在iPhone 显示一个 星级评分

http://blog.csdn.net/fanjunxi1990/article/details/8663914

由于项目需求,需要做一个列表,里面有各个商品的评分,就是app store里面所有app的星级评分

下面是DisplayStarView.h

[csharp] view plaincopy

  1. //
  2. //  DisplayStarView.h
  3. //  testExpress
  4. //
  5. //  Created by Juncy_Fan on 13-3-12.
  6. //  Copyright (c) 2013年 Juncy_Fan. All rights reserved.
  7. //
  8. #import <Foundation/Foundation.h>
  9. @interface DisplayStarView : UIView
  10. {
  11. CGFloat _starSize;        /* 根据字体大小来确定星星的大小 */
  12. NSInteger _maxStar;      /* 总共的长度 */
  13. NSInteger _showStar;    //需要显示的星星的长度
  14. UIColor *_emptyColor;   //未点亮时候的颜色
  15. UIColor *_fullColor;    //点亮的星星的颜色
  16. }
  17. @property (nonatomic, assign) CGFloat starSize;
  18. @property (nonatomic, assign) NSInteger maxStar;
  19. @property (nonatomic, assign) NSInteger showStar;
  20. @property (nonatomic, retain) UIColor *emptyColor;
  21. @property (nonatomic, retain) UIColor *fullColor;
  22. @end

DisplayStarView.m如下

[csharp] view plaincopy

  1. //
  2. //  DisplayStarView.m
  3. //  testExpress
  4. //
  5. //  Created by Juncy_Fan on 13-3-12.
  6. //  Copyright (c) 2013年 Juncy_Fan. All rights reserved.
  7. //
  8. #import "DisplayStarView.h"
  9. @implementation DisplayStarView
  10. @synthesize starSize = _starSize;
  11. @synthesize maxStar = _maxStar;
  12. @synthesize showStar = _showStar;
  13. @synthesize emptyColor = _emptyColor;
  14. @synthesize fullColor = _fullColor;
  15. - (id)initWithFrame:(CGRect)frame
  16. {
  17. self = [super initWithFrame:frame];
  18. if (self)
  19. {
  20. self.backgroundColor = [UIColor clearColor];
  21. //默认的星星的大小是 13.0f
  22. self.starSize = 13.0f;
  23. //未点亮时的颜色是 灰色的
  24. self.emptyColor = [UIColor colorWithRed:167.0f / 255.0f green:167.0f / 255.0f blue:167.0f / 255.0f alpha:1.0f];
  25. //点亮时的颜色是 亮黄色的
  26. self.fullColor = [UIColor colorWithRed:255.0f / 255.0f green:121.0f / 255.0f blue:22.0f / 255.0f alpha:1.0f];
  27. //默认的长度设置为100
  28. self.maxStar = 100;
  29. }
  30. return self;
  31. }
  32. //重绘视图
  33. - (void)drawRect:(CGRect)rect
  34. {
  35. // Drawing code
  36. CGContextRef context = UIGraphicsGetCurrentContext();
  37. NSString* stars = @"★★★★★";
  38. rect = self.bounds;
  39. UIFont *font = [UIFont boldSystemFontOfSize:_starSize];
  40. CGSize starSize = [stars sizeWithFont:font];
  41. rect.size=starSize;
  42. [_emptyColor set];
  43. [stars drawInRect:rect withFont:font];
  44. CGRect clip = rect;
  45. clip.size.width = clip.size.width * _showStar / _maxStar;
  46. CGContextClipToRect(context,clip);
  47. [_fullColor set];
  48. [stars drawInRect:rect withFont:font];
  49. }
  50. - (void)dealloc
  51. {
  52. [_emptyColor release];
  53. [_fullColor release];
  54. [super dealloc];
  55. }
  56. @end

需要怎么去使用呢?很简单,值需要知道评分是多少就OK啦,比如

[csharp] view plaincopy

  1. //评论是4.2分的
  2. DisplayStarView *sv = [[DisplayStarView alloc]initWithFrame:CGRectMake(90, 90, 200, 40)];
  3. [self.view addSubview:sv];
  4. sv.showStar = 4.2*20;
  5. [sv release];
  6. //评论是2.5分的
  7. DisplayStarView *sv1 = [[DisplayStarView alloc]initWithFrame:CGRectMake(90, 90+40, 200, 40)];
  8. [self.view addSubview:sv1];
  9. sv1.showStar = 2.5 * 20;
  10. [sv1 release];
  11. //评论是4.8分的
  12. DisplayStarView *sv2 = [[DisplayStarView alloc]initWithFrame:CGRectMake(90, 90+40+40, 200, 40)];
  13. [self.view addSubview:sv2];
  14. sv2.showStar = 4.8 * 20;
  15. [sv2 release];

运行结果如图所示:

时间: 2024-11-04 17:15:48

如何在iPhone 显示一个 星级评分的相关文章

Vue实现一个星级评分组件

星级评分在WEB开发中经常可能会用到,因此把他封装成一个vue组件是很合适的,要做的效果如下: 因此我们需要通过后台传递过来的score来写业务逻辑 比如这个模拟数据,3.6分就应该是三颗半星,小于3.5分大于3分的依旧按3分判断 在设计给出的图标中单颗星级有无星级,半颗,以及一颗 根据星星的大小,还会给出24,36,48格式大小的星星,因此这个组件的逻辑还是比较复杂的 star组件需要两个从外部传递进来的参数,一个是star的大小,一个是分数 因此在props里定义这两个从外部传递进来的变量

干货之运用CALayer创建星级评分组件(五角星)

本篇记录星级评分组件的创建过程以及CALayer的运用. 为了实现一个星级评分的组件,使用了CALayer,涉及到mask.CGPathRef.UIBezierPath.动画和一个计算多角星关键节点的算法. CALayer管理基于图像的内容,并让我们可以在内容上添加动画.UIView及其子类拥有一个属性layer,我们可以运用该属性做出非常多的效果.例如圆角.多边形.甚至自定义形状的view,局部遮挡,擦除模糊效果,局部内容依次闪亮效果,弧形进度条等等. 首先查看CALayer的一个属性mask

jQuery Raty - 不错的星级评分插件

在做商品评价时,一般情况下,我们需要一个星级评分的组件,而jQuery Raty恰好满足我们的需求. 一.展示 二.使用教程 ①.下载插件 https://github.com/wbotelhos/raty ②.导入文件 <script type="text/javascript" src="${ctx}/components/raty/jquery.raty.js"></script> <link type="text/cs

js实现星级评分之方法一

利用一个星级评分的小案例,来逐步封装js星级评分插件. 从最基础的js知识,通过一个小的demo,逐步学习js的面向对象知识. 从浅到深,逐步递进. 图片素材 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>星级评分--第一种实现方式</title> </head> <style type="text/css&quo

星级评分进度条(RatingBar)

星级评分进度条(RatingBar):(主要用于评价等方面) 常用的xml属性; android:isIndicator:RatingBar是否是一个指示器(用户无法进行更改) android:numStars:显示的星星数量,必须是一个整型值,如“100”. android:rating:默认的评分,必须是浮点类型,像“1.2”. android:stepSize:评分的步长,必须是浮点类型,像“1.2”. 常用的方法: 监听方法:setOnRatingBarChangelistener 监听

【Android】下拉列表、拖动条、星级评分条与标签文本的触摸事件

下拉列表.拖动条与星级评分条都是Android中的一些基本组件. 写一个小小的程序,来说明其用法. 如下图: 当下拉列表有值选定之后,则弹出相应的提示信息,哪个值被选择.星际评分条也一样,获取用户选择的星数. 标签文本被触摸则显示其被触摸. 滑动条,在拖动的时候,则在标签文本显示其值.因为,如果用弹出消息显示其滑动值,很不顺畅. 首先,把res\values\strings.xml,修改成如下代码: <?xml version="1.0" encoding="utf-8

数组练习:各种数组方法的使用&amp;&amp;事件练习:封装兼容性添加、删除事件的函数&amp;&amp;星级评分系统

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-

Android进度条(星级评分)使用详解(二)

一.SeekBar拖动条使用 SeekBar继承于ProgressBar,ProgressBar所支持的XML属性和方法完全适用于SeekBar.拖动条和进度条的区别是:进度条采用颜色填充来表明进度完成的程度,而拖动条则通过滑块位置来标识数值并且运行用户拖动滑块来改变值.因此,拖动条通常用于对系统的某种数值进行调节,比如调节音量.图片的透明度等. 1.拖动条效果 2.代码实现 功能:通过拖动滑块该动态改变图片的透明度 public class MainActivity extends Actio

ExtJS(3)- 自定义组件(星级评分)

今天介绍ExtJS的组件开发,这里以星级评分为示例,首先来看看效果图: 然后是功能操作:鼠标移动到五个星星上面时,会有tooltip显示当前的分值.如图:鼠标悬停在第四颗星星时前四颗星星显示高亮笑脸,当点击下去时锁定笑脸并且设定份数为4. 然后我们来说一下实现原理,Ext的组件基本单元是Ext.Component,所以自定义组件可以继承Component,然后显示部分直接用html来显示,包括css和动态事件都可以直接在html上编辑添加. 接下来我们来看代码: Ext.define('Pact