iOS之星星评分(一)

作者: Mr_Victory | 来源:发表于2016-05-30 21:11 被阅读1285次
  在ios开发中,我们可能会遇到评分这类需求。 比如我有一个商品列表,现在我们需要给列表中的各个商品进行评分。(见下图)那该怎么做呢?
星星评分.png

今天我们说的第一种评分,是不可以点击评分的。 也就是说星星点亮的多少不是我们手动点击的,而是服务器返回一个数字,然后根据数字所占的百分比来计算星星的个数。那下面我们开始吧~

// 首先,我们创建一个继承UIView 的 StarView 的类,在.文件中有如下属性:

// 根据字体大小来确定星星的大小
@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;

下面是具体实现

// 重写initWithFrame:方法
- (instancetype)initWithFrame:(CGRect)frame {
    
    if ( self = [super initWithFrame:frame]) {
        self.backgroundColor = [UIColor clearColor];
        // 星星的尺寸
        self.starSize = 20.0f;
        // 未点亮星星的颜色(可根据自己喜好设定)
        self.emptyColor = TSColor(167, 167, 167);
        // 点亮星星的颜色
        self.fullColor = TSColor(16, 130, 225);
        // 默认长度
        self.maxStar = 100;
    }
    return self;
}

//重绘视图
- (void)drawRect:(CGRect)rect {
    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];
}

如何使用呢?

// 使用起来非常简单。就跟创建一个View一样。应为我这个类取名StarView,所以:
 StarView *starView =  [StarView alloc] initWithFrame:CGRectMake(90, 90, 200, 40)];
 [self.view addSubView:starView];
// 别忘了这一步哦(关键的一步),3*20 意思是我想显示3颗星。20是没个星星的宽度(因为 上面设置了self.maxStar = 100),我的最大星星个数是5,所以每个星星的宽度是20
starView.showStar = 3*20;
  今天所说的这种方法的原理是重绘。 注意:这种方法,用户是点击不了的,这种方法适用于评分是从服务器返回的。如果 需要用户自己手动评分(点击评分)的话,那就请见明天的文章《iOS之星星评分(二)》。 上面的代码直接拷贝就可以运行。为了以后考虑,建议跟我一下写在一个继承于UIView的类里面,方便调用。
  如果你对本文有什么好的意见,欢迎骚扰。可以私信我啊~~ 我会把代码整理后,放到github上,3Q~~。

相关文章

  • iOS之星星评分(一)

    今天我们说的第一种评分,是不可以点击评分的。 也就是说星星点亮的多少不是我们手动点击的,而是服务器返回一个数字,然...

  • iOS 星星评分控件

    简单的自用星星控件,有空再加上手势 星星的间距取的是星星的宽度的五分之一,view的宽度等于五个星星加上四个空隙 ...

  • LBStarView 星星iOS评分

    效果图 Github : https://github.com/LeonLeeboy/LBStarView 只需要...

  • 评分功能

    iOS系统中没有自带的星星评分功能,需要自己封装。星星评分功能是整个工程的一个需求,但是代码的封装则是一个代码功底...

  • iOS评分星星允许半颗

    你的喜欢是我的坚持的动力! .m如下 .h如下 如何使用呢?一句话

  • iOS之星星评分(二)

    首先我们创建一个基于UIView的类,就叫YYStarView吧。在YYStarView.h文件中我们写下如下代码...

  • iOS - 仿淘宝星星评分

    前言: 最近项目中做商城,涉及到订单评价,评分的问题,网上参考了别人的一些资料,然后封装了一套可以实现评分功能的方...

  • ios-提示星星评分

  • 【iOS】一个星星评分控件

    实现思路 1、使用互相重叠的两套星星,将上面的一套星星添加到一个clipsToBounds = YES的容器视图V...

  • 星星评分

    关于评价星级的基本原理 主要根据鼠标滑过改变元素的背景图片造成评价的结果。 评价 控制台输出了slice,spli...

网友评论

  • 往事如烟_想戒_难:可以手势滑动的呢
  • 国王or乞丐:大神,不知道为嘛不能设置不能点击呢?
    Mr_Victory:@国王or乞丐 请仔细看第二篇,它的内部就是用的imageView。
    国王or乞丐:@Mr_Victory 但是你另一种也不是图片哎,不知道换成图片是否可以,我下周会发一个我写的,这周没时间整理了
    Mr_Victory:@国王or乞丐 你要仔细看啊,我在文中说明了,这第一种是不能点击的,我还有另一篇文章,星星评分(二),那个可以点击。
  • Mr_Bob_:好牛逼的大神,星星评分,可以的
  • dlxfly:谢谢大神 想想自己用的imgView .....
  • 22dcea9df62f:大神你这个有没有完整的Demo啊,求私发一下
    Mr_Victory:@社会你嘚瑟哥 要看你需要什么样的效果了。都是项目中的,接口都是保密的,你懂的。
  • 芝麻绿豆:给你两张图片,一张是五个灰色的,一张是五颗橙色的!如果是三分就是三个橙色的两个灰色的!对于这需求有啥想法?
    Mr_Victory:@芝麻绿豆可以做到,看明天的文章吧:smile:

本文标题:iOS之星星评分(一)

本文链接:https://www.haomeiwen.com/subject/golcdttx.html