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

首頁 > 系統 > iOS > 正文

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

2020-07-26 02:25:48
字體:
來源:轉載
供稿:網友

前言

在開發中,特別是銷售企業內部使用的APP,可能會用到數據匯總,使用到圖表的功能!本文主要給大家介紹了關于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的時候,若發現其版本是指定的版本,就不會更新了。

總結

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产视频欧美视频| 欧美午夜无遮挡| 欧美中文在线字幕| 亚洲精品小视频在线观看| 日韩美女视频在线观看| 欧美丰满少妇xxxx| 亚洲一区二区三区在线视频| 亚洲精品综合精品自拍| 欧美寡妇偷汉性猛交| 色偷偷88888欧美精品久久久| 国产亚洲aⅴaaaaaa毛片| 国产精品香蕉在线观看| 国产精品日韩电影| 麻豆一区二区在线观看| 久久精品国产免费观看| 538国产精品视频一区二区| 国产精品久久久久久久久久久不卡| 亚洲国产一区自拍| 中文字幕亚洲欧美在线| 久久久久久久国产精品视频| 亚洲影视九九影院在线观看| 91精品国产网站| 亚洲大胆人体av| 亚洲人成亚洲人成在线观看| 亚洲综合在线播放| 欧美成人一区在线| 国产成人高清激情视频在线观看| 亚洲欧美中文日韩v在线观看| xxx一区二区| 高清日韩电视剧大全免费播放在线观看| 久久亚洲成人精品| xx视频.9999.com| 国产一区玩具在线观看| 成人444kkkk在线观看| 亚洲毛片在线免费观看| 精品夜色国产国偷在线| 日韩av电影院| 亚洲a级在线观看| 庆余年2免费日韩剧观看大牛| 亚洲精品一区二区网址| 国产日产亚洲精品| 国产日韩精品视频| 日韩有码在线观看| 555www成人网| 精品视频偷偷看在线观看| 国产精品大片wwwwww| 美女啪啪无遮挡免费久久网站| 欧美日韩性视频在线| 亚洲成人精品久久久| 高清在线视频日韩欧美| 亚洲精品一区二区三区不| 日韩欧美亚洲范冰冰与中字| 国产不卡av在线免费观看| 欧美视频一二三| 8050国产精品久久久久久| 日韩精品日韩在线观看| 欧美激情精品久久久久久免费印度| 欧美精品生活片| 久久久久久12| 日韩av影片在线观看| 日韩hd视频在线观看| 国产精品国模在线| 欧美日韩国产影院| 日韩一区在线视频| 亚洲精品美女免费| 亚洲a∨日韩av高清在线观看| 日韩有码在线视频| 精品色蜜蜜精品视频在线观看| 亚洲精品久久久久国产| 久久国产精品久久精品| 海角国产乱辈乱精品视频| 亚洲视频在线观看| 欧美与欧洲交xxxx免费观看| 久久国产精品久久久| 日韩少妇与小伙激情| 精品偷拍各种wc美女嘘嘘| 久久视频在线视频| 欧美一区二区.| 欧美日韩中文在线观看| 亚洲欧美在线第一页| 日韩欧美国产成人| 亚洲欧洲日产国码av系列天堂| 日韩高清人体午夜| 国产在线观看不卡| 久久久久这里只有精品| 久久久久久久久久久91| 亚洲欧美国产制服动漫| 国产精品爽爽爽爽爽爽在线观看| 国产精品美女无圣光视频| 欧美激情aaaa| 日韩网站免费观看| 国产91精品久| 国产日韩欧美日韩大片| 国产午夜精品一区二区三区| 亚洲深夜福利网站| 26uuu亚洲国产精品| 精品国内自产拍在线观看| 日本中文字幕久久看| 欧美色视频日本版| 欧美午夜www高清视频| 亚洲欧美色婷婷| 2019亚洲男人天堂| 欧洲美女7788成人免费视频| 亚洲国产婷婷香蕉久久久久久| 91色视频在线导航| 亚洲美女自拍视频| 久久久99久久精品女同性| 亚洲国产高清高潮精品美女| 亚洲国产第一页| 亚洲国产精彩中文乱码av在线播放| 国产精品日韩久久久久| 欧美成人精品h版在线观看| 亚洲香蕉在线观看| 精品国产一区二区三区久久狼黑人| 色婷婷久久一区二区| 亚洲天天在线日亚洲洲精| 成人激情电影一区二区| 国产精品丝袜白浆摸在线| 在线观看视频亚洲| 国产精品白嫩初高中害羞小美女| 欧美日韩国产综合新一区| 精品国产精品三级精品av网址| 欧美香蕉大胸在线视频观看| 国产热re99久久6国产精品| 国产精品欧美风情| 琪琪第一精品导航| 国内精品久久久久久久| 成人做爽爽免费视频| 久久影院资源站| 欧美性xxxx| 亚洲日韩欧美视频一区| 欧美亚洲一区在线| 国产欧美日韩精品丝袜高跟鞋| 国产精品久久久av| 国产精品露脸av在线| 久久电影一区二区| 亚洲伊人第一页| 欧美在线xxx| 久久最新资源网| 欧美裸体男粗大视频在线观看| 欧美成人免费全部| 欧美性猛交xxxx乱大交蜜桃| 亚洲欧美日韩中文在线制服| 久久精品久久久久久| 91精品免费视频| 亚洲性生活视频| 亚洲视频一区二区| 国产精品免费视频xxxx| 欧美另类在线观看| 成人性生交大片免费看小说| 日韩av网址在线观看| 国产精品久久不能| 国产美女精彩久久| 国产一区二区美女视频| 亚洲午夜女主播在线直播| 中文字幕在线看视频国产欧美在线看完整| 亚洲人成亚洲人成在线观看| 操日韩av在线电影| 久久频这里精品99香蕉| 国产一区二区三区在线视频| 日韩福利伦理影院免费| 欧美日韩免费一区| 国产欧美一区二区三区久久| 在线亚洲男人天堂|