[iOS]实现多方向拖拽EXCEL表格中遇到的问题

之前在写一个类似于Excel表格页面时,一种方式是可以实现可以上下左右及斜角联动,另一种方式只可以上下左右联动。之所以提及这两种方式主要是在开发过程中第一种遇到了内存占用大问题,所以最终用了第二种方式实现Excel表格页面。 Demo传送门,若有实现同样需求的可以作为参考。

效果图.jpeg

思路:

第一种方式:左边用一个搭一个tableView显示每行标题,顶部物料编码用一个UIView显示,顶部用一个collectionView填列标题,中间用一个srollerView再将tableview放其上填满

#pragma mark - 右侧详情页面

- (void)loadDetailView {
    _detailScrollView = [[UIScrollView alloc] initWithFrame:CGRectMake(kAverageTableViewWidth, topConllectionCellH, kAverageTableViewWidth*2, kScreenHeight)];
    _detailScrollView.tag           =   DetailScrollViewTag;
    _detailScrollView.bounces       =   false;
    _detailScrollView.delegate      =   self;
    _detailScrollView.showsVerticalScrollIndicator      =  false;
    _detailScrollView.showsHorizontalScrollIndicator    =  false;
    _detailScrollView.contentSize   =   CGSizeMake(7*kAverageTableViewWidth, self.systransInquirystockArrays.count*rowHight);
    _detailScrollView.backgroundColor = [UIColor grayColor];
    
    
    _detailTableView = [[UITableView alloc]initWithFrame:CGRectMake(0, 0, kAverageTableViewWidth*7, self.systransInquirystockArrays.count*rowHight) style:UITableViewStylePlain];
    _detailTableView.dataSource = self;
    _detailTableView.delegate = self;
    _detailTableView.tag = MidTableViewTag;
    _detailTableView.separatorStyle = UITableViewCellSeparatorStyleNone;
    
    [self.view addSubview:_detailScrollView];
    
    [_detailScrollView addSubview:_detailTableView];
}

上面代码主要是中间详情的内容视图,因为我这里的有七列,所以将scrollerView 的滚动范围设成

_detailScrollView.contentSize   =   CGSizeMake(7*kAverageTableViewWidth, self.systransInquirystockArrays.count*rowHight);

宽为七列宽,高度为请求回来的数组有多少数组将其成以设定tableViewCell的高度有多少。同时将tableView Frame设置成等同于scrollerView的尺寸,四个控件在代理方法拖拽的处理如下:

/**
 
 判断拖动的view的tag进行联动
 */
- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    if (_currentScrollViewTag == TitleTableViewTag) {
        CGFloat offSetX = _beforeScrollViewTag == TopIconListViewTag ? _topIconListView.contentOffset.x : _detailScrollView.contentOffset.x;
        _detailScrollView.contentOffset = CGPointMake(offSetX, _titleTableView.contentOffset.y);
        _topIconListView.contentOffset = CGPointMake(offSetX, 0);
        return;
    }
    if (_currentScrollViewTag == DetailScrollViewTag) {
        _titleTableView.contentOffset = CGPointMake(0, _detailScrollView.contentOffset.y);
        _topIconListView.contentOffset = CGPointMake(_detailScrollView.contentOffset.x, 0);
        return;
    }
    if (_currentScrollViewTag == TopIconListViewTag) {
        CGFloat offSetY = _beforeScrollViewTag == TitleTableViewTag ? _titleTableView.contentOffset.y : _detailScrollView.contentOffset.y;
        _detailScrollView.contentOffset = CGPointMake(_topIconListView.contentOffset.x, offSetY);
        _titleTableView.contentOffset = CGPointMake(0, _detailScrollView.contentOffset.y);
        return;
    }
}

可以看到中间详情tableView在代理方法中没做任何处理,详情tableView是跟随着scrollerView动的。
这样就实现了拖拽上下左右及斜角方向时四个控件的联动联动。但这样有不足之处,当请求下来的数据不大时还好,但行数一旦达到上千行时,明显内存会占用很大

第一种方式.png
第二种方式.png

可以对比两图第一种方式当我 加载大量数据时,相对于第二种方式出现了严重的内存占用问题。起初没发觉是因为我加载的数据不多,当有人出现全查时就会有这种情况出现,我检查了内存是否存在泄漏及cell的复用的情况都没问题,但仔细看代码才发现我这种方案是有问题的,因为我把中间详情tableView的Frame设置成等同于scrollerView的尺寸,当全查时即高度等于cell的高度乘以1000,当加载tableView时把全部cell加载出来,每个cell有近10个对象创建,将相当于上万个对象在占用内存,当滑动到最后一个时才会启用cell的回收机制,还好都是一些label,若是每个cell中有图片后果可想而知。

第二种方式:同样是搭建如上所搭建的方式,但srollerView的滑动范围改成如下

_detailScrollView.contentSize   =   CGSizeMake(7*kAverageTableViewWidth, kScreenHeight);

中间详情的tableview的Frame改成如下:

 _detailTableView = [[UITableView alloc]initWithFrame:CGRectMake(0, 0, kAverageTableViewWidth*7, kScreenHeight)

拖拽的策略改成如下:

/**
 
 判断拖动的view的tag进行联动
 */
- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    if (_currentScrollViewTag == TitleTableViewTag) {
        //上一次点的是头部视图,内容试图的偏移量等于头部视图的偏移量,不然内容视图的偏移量等于本身的偏移量
        CGFloat offSetTableViewX = _beforeScrollViewTag == TopIconListViewTag ? _topIconListView.contentOffset.x : _detailTableView.contentOffset.x;
        _detailTableView.contentOffset = CGPointMake(offSetTableViewX, _titleTableView.contentOffset.y);
        return;
    }
    if (_currentScrollViewTag == MidTableViewTag) {
        _titleTableView.contentOffset = CGPointMake(0, _detailTableView.contentOffset.y);
        return;
    }
    if (_currentScrollViewTag == DetailScrollViewTag) {
        _topIconListView.contentOffset = CGPointMake(_detailScrollView.contentOffset.x, 0);
        return;
    }
}

当前拖拽中间详情tableview时,若是上下方向,识别的是中间详情的tableview,偏移量赋给左边行标题的tableview,若是左右方向时,识别的是tableview下的scrollerView的偏移量赋给头部的collectionView。当点击左边行标题的tableview如上代码注释。
这样的方案只创建看得见的cell,cell消失后就会启动cell的复用机制,所以内存不会怎么占用。但这样斜角拖拽方向没有实现。但上面最终竟然认可第二种方案,原因是斜角拖拽会有一种错乱感,虽然就这样去解决不是很好,以后再尝试在即保证内存优化的情况下实现第一种方式的excel表格吧。能力有限,有错求指正。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容