亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS中PNChart與UITableView的聯動示例詳解

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

前言

在開發中,特別是銷售企業內部使用的APP,可能會用到數據匯總,使用到圖表的功能!本文主要給大家介紹了關于iOS中PNChart與UITableView聯動的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧

效果圖

iOS,PNChart,UITableView,聯動

1.點擊chart,tableView對應模塊高亮

PNChart提供了一個代理方法,用來處理用戶的點擊事件:

#pragma mark - PNChart Delegate- (void)userClickedOnPieIndexItem:(NSInteger)pieIndex { for (int i = 0; i < self.model.department_sale.count; i++) { CQSaleDetailDepartmentItemModel *model = self.model.department_sale[i]; model.selected = (i == pieIndex); } [self.tableView reloadData]; [self.tableView scrollToRowAtIndexPath:[NSIndexPath indexPathForRow:pieIndex inSection:0] atScrollPosition:UITableViewScrollPositionMiddle animated:YES];}

2.點擊cell,chart對應模塊高亮

PNChart并未提供相應方法讓某一模塊高亮,怎么辦?

思路:

雖然PNChart未直接提供讓某一模塊高亮的方法,但是我們可以從用戶點擊模塊高亮那部分代碼入手,看看用戶點擊到模塊高亮是怎樣一個過程。

1.在PNPieChart.m里面找到touchesBegan方法:

- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event{ for (UITouch *touch in touches) { CGPoint touchLocation = [touch locationInView:_contentView]; [self didTouchAt:touchLocation]; }}

發現它調用了didTouchAt:方法。

2.分析didTouchAt:

- (void)didTouchAt:(CGPoint)touchLocation{ CGPoint circleCenter = CGPointMake(_contentView.bounds.size.width/2, _contentView.bounds.size.height/2);  CGFloat distanceFromCenter = sqrtf(powf((touchLocation.y - circleCenter.y),2) + powf((touchLocation.x - circleCenter.x),2));  if (distanceFromCenter < _innerCircleRadius) { if ([self.delegate respondsToSelector:@selector(didUnselectPieItem)]) {  [self.delegate didUnselectPieItem]; } [self.sectorHighlight removeFromSuperlayer]; return; }  CGFloat percentage = [self findPercentageOfAngleInCircle:circleCenter fromPoint:touchLocation]; int index = 0; while (percentage > [self endPercentageForItemAtIndex:index]) { index ++; }  if ([self.delegate respondsToSelector:@selector(userClickedOnPieIndexItem:)]) { [self.delegate userClickedOnPieIndexItem:index]; }  if (self.shouldHighlightSectorOnTouch) { if (!self.enableMultipleSelection) {  if (self.sectorHighlight)  [self.sectorHighlight removeFromSuperlayer]; }  PNPieChartDataItem *currentItem = [self dataItemForIndex:index];  CGFloat red,green,blue,alpha; UIColor *old = currentItem.color; [old getRed:&red green:&green blue:&blue alpha:&alpha]; alpha /= 2; UIColor *newColor = [UIColor colorWithRed:red green:green blue:blue alpha:alpha];  CGFloat startPercentage = [self startPercentageForItemAtIndex:index]; CGFloat endPercentage = [self endPercentageForItemAtIndex:index];  self.sectorHighlight = [self newCircleLayerWithRadius:_outerCircleRadius + 5       borderWidth:10       fillColor:[UIColor clearColor]       borderColor:newColor      startPercentage:startPercentage      endPercentage:endPercentage];  if (self.enableMultipleSelection) {  NSString *dictIndex = [NSString stringWithFormat:@"%d", index];  CAShapeLayer *indexShape = [self.selectedItems valueForKey:dictIndex];  if (indexShape)  {  [indexShape removeFromSuperlayer];  [self.selectedItems removeObjectForKey:dictIndex];  }  else  {  [self.selectedItems setObject:self.sectorHighlight forKey:dictIndex];  [_contentView.layer addSublayer:self.sectorHighlight];  } } else {  [_contentView.layer addSublayer:self.sectorHighlight]; } }}

通過源代碼我們可以發現,用戶點擊chart的時候,將傳入的參數touchLocation轉換成了index,這個index正是代理方法userClickedOnPieIndexItem:所需要的參數。另外,chart的某一模塊高亮,實際上是addSublayer:,而這個sublayer的屬性也是由index決定的。所以,通過主動調用一個方法讓chart的某個模塊高亮,關鍵就是這個index。

這樣的話,就很簡單了。只需把didTouchAt :的后半段代碼提出來,就是我們需要的新方法了:

/** 某一模塊高亮 @param index 高亮模塊的index */- (void)highlightItemWithIndex:(NSInteger)index { if (self.shouldHighlightSectorOnTouch) { if (!self.enableMultipleSelection) {  if (self.sectorHighlight)  [self.sectorHighlight removeFromSuperlayer]; }  PNPieChartDataItem *currentItem = [self dataItemForIndex:index];  CGFloat red,green,blue,alpha; UIColor *old = currentItem.color; [old getRed:&red green:&green blue:&blue alpha:&alpha]; alpha /= 2; UIColor *newColor = [UIColor colorWithRed:red green:green blue:blue alpha:alpha];  CGFloat startPercentage = [self startPercentageForItemAtIndex:index]; CGFloat endPercentage = [self endPercentageForItemAtIndex:index];  self.sectorHighlight = [self newCircleLayerWithRadius:_outerCircleRadius + 5       borderWidth:10       fillColor:[UIColor clearColor]       borderColor:newColor      startPercentage:startPercentage      endPercentage:endPercentage];  if (self.enableMultipleSelection) {  NSString *dictIndex = [NSString stringWithFormat:@"%ld", (long)index];  CAShapeLayer *indexShape = [self.selectedItems valueForKey:dictIndex];  if (indexShape)  {  [indexShape removeFromSuperlayer];  [self.selectedItems removeObjectForKey:dictIndex];  }  else  {  [self.selectedItems setObject:self.sectorHighlight forKey:dictIndex];  [_contentView.layer addSublayer:self.sectorHighlight];  } } else {  [_contentView.layer addSublayer:self.sectorHighlight]; } }}

現在就可以實現點擊cell,chart對應模塊高亮了:

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath { for (int i = 0; i < self.model.department_sale.count; i++) { CQSaleDetailDepartmentItemModel *model = self.model.department_sale[i]; model.selected = (i == indexPath.row); } [self.tableView reloadData]; [self.tableView scrollToRowAtIndexPath:[NSIndexPath indexPathForRow:indexPath.row inSection:0] atScrollPosition:UITableViewScrollPositionMiddle animated:YES]; // 對應的模塊高亮 [self.pieChart highlightItemWithIndex:indexPath.row];}

修改源碼注意事項

如果你的PNChart是手動拖進去的,修改源碼無所謂;

但如果是用CocoaPods管理的話,就要注意一下了:pod update的時候會覆蓋你寫的代碼。為避免這種事情發生,你可以指定庫的版本,如:

pod 'PNChart','0.8.9'

pod update的時候,若發現其版本是指定的版本,就不會更新了。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欲色天天网综合久久| 欧美亚洲在线观看| 亚洲欧美在线一区二区| 亚洲成人av片在线观看| 国产一区二区在线播放| 亚洲综合社区网| 久久免费成人精品视频| 国产精品美女主播在线观看纯欲| 国产精品久久久久久久7电影| 久久成人精品电影| 国产一区二区三区在线观看网站| 久久久久日韩精品久久久男男| 亚洲欧美在线磁力| 日韩中文字幕免费| 午夜精品久久久久久久男人的天堂| 亚洲欧美中文日韩v在线观看| 中文字幕免费精品一区高清| 久久视频在线观看免费| 亚洲视屏在线播放| 日本人成精品视频在线| 91成人免费观看网站| 色婷婷成人综合| 亚洲欧洲日产国产网站| 久久精品电影网站| 亚洲国产精品久久久久秋霞不卡| 国产精品福利片| 亚洲直播在线一区| 91精品国产综合久久香蕉922| 国产日韩精品电影| 久久久久久美女| 亚洲欧美日韩视频一区| 久久久精品免费| 日本免费一区二区三区视频观看| 国产综合在线观看视频| 日韩成人在线视频网站| 欧美视频中文在线看| 国产一级揄自揄精品视频| 2025国产精品视频| 中文字幕av一区| 成人h片在线播放免费网站| 久久精品国产69国产精品亚洲| 成人信息集中地欧美| 久久久久国产精品一区| 久久国产精品久久久| 国产精品男女猛烈高潮激情| 国内精品美女av在线播放| 国产日韩欧美夫妻视频在线观看| 亚洲第一精品夜夜躁人人爽| 久久久国产视频| 国产xxx69麻豆国语对白| 青青草99啪国产免费| 91免费电影网站| 欧美一级视频在线观看| 国产精品亚洲网站| 日韩av不卡电影| 欧美日韩国产在线播放| 国产精品一区二区三区免费视频| 日韩av在线免费观看| 91九色综合久久| 国产不卡一区二区在线播放| 久久精品99无色码中文字幕| 国产精品久久久久7777婷婷| 国产一区欧美二区三区| www.久久撸.com| 亚洲四色影视在线观看| 精品国产91乱高清在线观看| 亚洲一区二区自拍| 日韩电影中文字幕在线| 91精品视频在线看| 欧美xxxwww| 亚洲天堂开心观看| 亚洲成人亚洲激情| 美日韩精品免费观看视频| 最好看的2019的中文字幕视频| 亚洲亚裔videos黑人hd| 亚洲色图18p| 亚洲经典中文字幕| 日韩精品电影网| 国模视频一区二区| 久久免费视频在线观看| 亚洲www视频| 中文字幕欧美精品在线| 色樱桃影院亚洲精品影院| 国产丝袜精品第一页| 在线观看精品自拍私拍| 久久99久久亚洲国产| 久久成人综合视频| 狠狠躁夜夜躁人人爽超碰91| 久久久久久久久国产精品| 精品人伦一区二区三区蜜桃网站| 日韩精品中文在线观看| 精品电影在线观看| 成人欧美一区二区三区在线湿哒哒| 精品福利视频导航| 亚洲精品大尺度| 亚洲伊人第一页| 日韩av中文字幕在线| 国产日韩欧美另类| xvideos亚洲| 亚洲最新视频在线| 精品国产一区二区三区久久狼5月| 欧美怡红院视频一区二区三区| 91九色单男在线观看| 色综合久久精品亚洲国产| 亚洲欧美日韩国产精品| 欧美精品激情视频| 日韩成人在线视频观看| 日韩av片免费在线观看| 国产成人精品日本亚洲| 久久精品国产精品亚洲| 国产91色在线|免| 欧美在线视频播放| 97视频在线观看免费高清完整版在线观看| 日韩亚洲一区二区| 一区二区福利视频| 尤物九九久久国产精品的分类| 亚洲女人天堂视频| 91色琪琪电影亚洲精品久久| 久久精品免费播放| 91日本视频在线| 亚洲色图13p| 亚洲激情 国产| 91在线中文字幕| 久久国产色av| 久久这里只有精品视频首页| 亚洲国产精品久久久久久| 欧美亚洲视频一区二区| 国产精品中文在线| 欧美大片在线看免费观看| 国产成人精品999| 亚洲成人免费在线视频| 欧美性xxxxxxx| 97欧美精品一区二区三区| 全色精品综合影院| 欧美黄色三级网站| 亚洲日韩中文字幕在线播放| 国产精品久久久久久久久借妻| 成人黄色在线免费| 国产精品视频资源| 亚洲国模精品一区| 久久久久国产精品www| 欧美成人午夜激情| 欧美成人一区二区三区电影| 亚洲欧洲日本专区| 一个色综合导航| 欧美成人在线免费视频| 亚洲精品久久在线| 久久人人爽人人爽人人片亚洲| 久久国产加勒比精品无码| 欧美做受高潮电影o| 国产精品露脸av在线| 高清日韩电视剧大全免费播放在线观看| 第一福利永久视频精品| 欧美性猛交xxxx久久久| 国产精品视频久久| 国产亚洲欧美另类中文| 青青草原成人在线视频| 欧美精品性视频| 欧美日韩亚洲网| 久久综合伊人77777| 精品一区二区电影| 欧美美女18p| 中文字幕av一区二区| 欧美精品videosex极品1|