首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 移动开发 > Iphone >

UITableView 加载图片 卡的有关问题

2013-07-01 
UITableView加载图片卡的问题UITableView- (NSInteger)tableView:(UITableView *)tableView numberOfRowsI

UITableView 加载图片 卡的问题
UITableView

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    return 100;
}


- (UITableViewCell*)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    static NSString * cellID = @"cellID";
    
    UITableViewCell * cell = [tabView dequeueReusableCellWithIdentifier:cellID];
    
    if( nil == cell )
    {
        cell = [[[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:cellID] autorelease];
    }

    {
        UIImageView * goodsImageView;
        goodsImageView = [[[UIImageView alloc] initWithFrame:CGRectMake(10.5, 14, 297.5, 209)]autorelease];
        goodsImageView.opaque = YES;
        [cell.contentView addSubview:goodsImageView];
        goodsImageView.image = [UIImage imageNamed:@"img_topic"];
        
    }
    
    cell.selectionStyle = UITableViewCellSelectionStyleNone;

    return cell;
}

图片并不是从网上下载的  ,刚开始的时候滚动还挺流畅的,但是滚动了 一段事件后,没有刚开始这么流畅了,特别是在减速的时候,可以看到一卡一卡的现象

应该如何解决?
[解决办法]
为啥不自定义cell呢,直接在xib中加入图片不可以吗?
我在做的时候没遇到卡的现象
[解决办法]
首先,100行肯定会卡一点的,少加载一点会好些。
其次,这里还是用自定义UITableViewCell吧,你这样也会影响效率。
像你这样,重用机制几乎没起到应有的效果。
再者,图片如果预先加载好了,比如UIImage都先加载好放到内存里,比如NSArray,用的时候直接拿出来用,不要临时从资源或目录中加载,也会快点。
[解决办法]

引用:
为啥不自定义cell呢,直接在xib中加入图片不可以吗?
我在做的时候没遇到卡的现象


我觉得楼主的图片应该是动态的,各不相同的,否则,的确是直接在IB中加载更快。
[解决办法]
楼上说的有道理!支持一下。
[解决办法]
300*200像素的100张图片,内存吞吐量不小啊。
可以考虑分步或者异步加载。

[解决办法]
1个像素4个字节,300*200*4=240000Byte
240000/1024=234.375MB
你程序运行到最后时会有这么大的内存开销
[解决办法]
方法不少啊。
第一,写到括号里面重用啊。
第二,图片这么多,可以滑动到哪里停止了以后,在进行显示。显示当前屏幕上出现的几行。
[解决办法]
首先,我不认为自定义UITableViewCell就一定高。

你的问题主要是处理加载数据策略的问题。你当然不能100张图片一次性的加载到内存当中,这时你就需要采取方法来实现,一般的我们常用的做法是(上面有人也提到了)分步加载(不一次载入全部的数据)也就“懒加载 lazy load”.先载入一部分,在下滑时再加载另一部分。 
再者就是可以使用一下“代理”来处理图像的加载,图像未显示前可以显示一个占位图,图片加载完成后,再显示出图片,主要原理还是异步加载,后台处理图片的加载,加载完成后更新主线程上的UI
[解决办法]
if( nil == cell )
    {
        cell = [[[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:cellID] autorelease];


       UIImageView * goodsImageView;
        goodsImageView = [[[UIImageView alloc] initWithFrame:CGRectMake(10.5, 14, 297.5, 209)]autorelease];
        goodsImageView.opaque = YES;
        [cell.contentView addSubview:goodsImageView];
    }
     goodsImageView.image = [UIImage imageNamed:@"img_topic"];//依据你对应行对应图片,设置
   这样就不会了。

问题:没有充分理解tablecell的实现机制,建议仔细阅读uitableview 的文档。
        

 
[解决办法]

引用:
if( nil == cell )
    {
        cell = [[[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:cellID] autorelease];
       UIImageView * goodsImageView;
  ……

这么多人回答,只有这个答案的原理算是靠谱的。
你的cell的contentView上面在不停的堆UIImageView,刚开始还行,越滑动堆得越多,不卡才怪。
不过上述代码你直接复制过去肯定编译不过,因为goodsImageView是局部变量。常见的方法是通过view的tag来访问goodsImageView。
if (!cell)
{
...
goodsImageView.tag = indexPath.hash; // 这里猜测你每个indexPath中显示的都是不同的内容。不过最好你能自己定义一下tag的值,保证其唯一性。
...
}
[(UIImageView *)[cell.contentView viewWithTag:indexPath.tag] setImage:[UIImage imageNamed:@"img_topic"]];

热点排行