国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > iOS > 正文

iOS上下文實現評價星星示例代碼

2019-10-21 18:47:19
字體:
來源:轉載
供稿:網友

常規思路:

創建兩個 view,通過 for 循環創建 imageView,未點亮星星視圖在下、點亮星星視圖在上重合在一起,當用戶點擊視圖時,通過改變點亮星星視圖的 width 實現功能

本文思路:

直接重寫 drawrect 方法,在 drawrect 用 drawimage 畫出星星,根據 currentValue 畫出不同類型的星星,當用戶點擊視圖時,改變 currentValue,并根據改變后的 currentValue 重新畫出星星。

展示圖:

ios,評價星星,實現評價小星星,評價星星如何實現

代碼:

自定義一個繼承 UIView 的 CYStarView

屬性:

/** 完成后執行的block */@property (copy, nonatomic) void(^completionBlock)(NSInteger);/** 是否可以點擊 */@property (assign, nonatomic) BOOL clickable;/** 星星個數 */@property (assign, nonatomic) NSInteger numberOfStars;/** 星星邊長 */@property (assign, nonatomic) CGFloat lengthOfSide;/** 評價值 */@property (assign, nonatomic) NSInteger currentValue;/** 星星間隔 */@property (assign, nonatomic) CGFloat spacing;

重寫 setter 方法,在 setter 方法中調用 setNeedsDisplay,會執行 drawrect:

- (void)setLengthOfSide:(CGFloat)lengthOfSide {  // 超過控件高度  if (lengthOfSide > self.frame.size.height) {    lengthOfSide = self.frame.size.height;  }  // 超過控件寬度  if (lengthOfSide > self.frame.size.width / _numberOfStars) {    lengthOfSide = self.frame.size.width / _numberOfStars;  }  _lengthOfSide = lengthOfSide;  _spacing = (self.frame.size.width - lengthOfSide * _numberOfStars) / _numberOfStars;  [self setNeedsDisplay];}

在 drawrect 中畫星星:

- (void)drawRect:(CGRect)rect {  UIImage *lightImage = [UIImage imageNamed:@"star_light"];  UIImage *darkImage = [UIImage imageNamed:@"star_dark"];  // 獲取當前上下文  CGContextRef context = UIGraphicsGetCurrentContext();  for (int i = 0; i < self.numberOfStars; i ++) {    // 根據 currentValue 選擇是畫亮的還是暗的星星    UIImage *image = i >= self.currentValue ? darkImage : lightImage;    CGRect imageRect = CGRectMake(self.spacing / 2 + (self.lengthOfSide + self.spacing) * i, (self.frame.size.height - self.lengthOfSide) / 2, self.lengthOfSide, self.lengthOfSide);    CGContextSaveGState(context);    // 坐標系Y軸是相反的,進行翻轉    CGContextScaleCTM(context, 1.0, - 1.0);    CGContextTranslateCTM(context, 0, - rect.origin.y * 2 - rect.size.height);    CGContextDrawImage(context, imageRect, image.CGImage);    CGContextRestoreGState(context);  }}

使用:

在要使用的控制器中:

#import "CYStarView.h"// 初始化,傳入必要參數CYStarView *starView = [[CYStarView alloc] initWithFrame:frame numberOfStars:number lengthOfSide:length];// 設置 clickable,評論界面設置為YES,展示界面設置為NOself.starView.clickable = YES;// // 設置 completionBlockself.starView.completionBlock = ^(NSInteger currentValue) {  // 點擊后的操作放這里};

項目地址:點我點我!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 河间市| 吴旗县| 鄂伦春自治旗| 柳河县| 三都| 许昌县| 长岛县| 辰溪县| 白水县| 汤阴县| 杭锦后旗| 广灵县| 福建省| 象山县| 丰原市| 常州市| 孝昌县| 封开县| 安岳县| 嘉黎县| 施甸县| 丰顺县| 东辽县| 大同市| 叙永县| 微山县| 兴隆县| 罗定市| 从江县| 逊克县| 湘阴县| 贺兰县| 汾西县| 博兴县| 宜黄县| 枞阳县| 盐津县| 探索| 新竹市| 龙川县| 卢龙县|