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

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

下面是DisplayStarView.h

  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如下

  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啦,比如

  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];

运行结果如图所示:

 

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

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

    本篇记录星级评分组件的创建过程以及CALayer的运用. 为了实现一个星级评分的组件,使用了CALayer,涉及到mask.CGPathRef.UIBezierPath.动画和一个计算多角星关键节点的 ...

  2. Angular 星级评分组件

    一.需求演变及描述: 1. 有一个“客户对公司的总体评价”的字段(evalutation).字段为枚举类型,0-5,对应关系为:0-暂无评价,1-很差,2-差,3-一般,4-好,5-很好 2. 后来需 ...

  3. js 实现星级评分

    最近的项目中有一个星级评分的需求,  自己就写了一下, 由于可能一个页面要用到多个,就采用了面向对象的写法. 用到的png图片也放到这里.    js要用到jquery. css: .sr-star{ ...

  4. js实现星级评分之方法一

    利用一个星级评分的小案例,来逐步封装js星级评分插件. 从最基础的js知识,通过一个小的demo,逐步学习js的面向对象知识. 从浅到深,逐步递进. 图片素材 <!DOCTYPE html> ...

  5. 星级评分进度条(RatingBar)

    星级评分进度条(RatingBar):(主要用于评价等方面) 常用的xml属性; android:isIndicator:RatingBar是否是一个指示器(用户无法进行更改) android:num ...

  6. 用css制作星级评分

    Step 1: XHTML <ul class="star-rating">       <li><a href="#" titl ...

  7. Android 拖动条/滑动条控件、星级评分控件

    ProgressBar有2个子控件: SeekBar   拖动条控件 RatingBar   星级评分控件 1.拖动条控件 <SeekBar android:layout_width=" ...

  8. 原生JS实现-星级评分系统

    今天我又写了个很酷的实例:星级评分系统(可自定义星星个数.显示信息) sufuStar.star();使用默认值5个星星,默认信息 var msg = [........]; sufuStar.sta ...

  9. javascript星级评分(多个)

    JS打多个类型星级评分: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http: ...

随机推荐

  1. linear-gradient

    http://jsbin.com/mocojehosa/edit?html,css,output https://developer.mozilla.org/zh-CN/docs/Web/CSS/li ...

  2. 微信小程序上传报错:以下文件没有被打包上传: · .gitignore

    简单粗暴的办法就是:找到gitignore文件,把该文件删除掉即可. 在使用Git的过程中,我们喜欢有的文件比如日志,临时文件,编译的中间文件等不要提交到代码仓库,这时就要设置相应的忽略规则,来忽略这 ...

  3. touch滑动事件---简单小案例

    html: <!--导航栏头部--><div class="type_nav"> <ul class="clearfix " v- ...

  4. PAT甲级——A1025 PAT Ranking

    Programming Ability Test (PAT) is organized by the College of Computer Science and Technology of Zhe ...

  5. windows2008解决必须使用角色管理工具安装或配置 NET3.5 sp1问题

    win2008系统安装网站环境系统的时候常常提示:必须使用角色管理工具 安装或配置microsoft.net framework 3.5 sp1 ,导致安装不成功. 原因在于windows2008系统 ...

  6. 二、深入asyncio协程(任务对象,协程调用原理,协程并发)

      由于才开始写博客,之前都是写笔记自己看,所以可能会存在表述不清,过于啰嗦等各种各样的问题,有什么疑问或者批评欢迎在评论区留言. 如果你初次接触协程,请先阅读上一篇文章初识asyncio协程对asy ...

  7. CentOS 6.8 Linux系统U盘制作启动项

    1.下载CentOS 6.8镜像文件: 2.下载地址:http://man.linuxde.net/download/CentOS_6_8 3.准备一个U盘,最好8G的: 4.下载UltraISO盘制 ...

  8. 2019.10.29 csp-s模拟测试93 反思总结

    T1: 求出前缀和,三维偏序O(nlog2n)CDQ 二维其实就可以 #include<iostream> #include<cstdio> #include<cstri ...

  9. meta标签中设置apple-itunes-app的意义

    告诉iphone的safari浏览器:这个网站对应的是哪个app <meta name="apple-itunes-app" content="app-id=589 ...

  10. 傻瓜式教程--实现登录页面的验证码以及验证(VUE)

    做成之后就 是这个样子 接下来上代码创建一个组件.显示验证码图片 <template> <div class="s-canvas"> <canvas ...