gpt4 book ai didi

ios - UITableViewCells 中的图像加载错误

转载 作者:技术小花猫 更新时间:2023-10-29 11:24:40 26 4
gpt4 key购买 nike

我正在开发一个应用程序,我想在带有自定义单元格的 UITableView 中显示几乎与屏幕大小一样大的图像。图像加载良好,但加载速度有点慢,但是当我在 TableView 中滚动时,它们出现在错误的单元格中(例如 Cell5 中的 Image1 应该出现在 Image5 中)1 或 2 秒后正确的图像出现。为了不需要太多的数据流量,我考虑了一个类似“缓存”的 URL/图像存储:

- (id) init
{
if (self = [super init]) {
self.cacheStoreDictionary = [NSMutableDictionary new];
}
return self;
}

- (void) startLoadingImageWithUrl:(NSString *)urlString forItem:(id)item
{
if (self.cacheStoreDictionary[urlString]) {
UIImage *image = self.cacheStoreDictionary[urlString];
[self.delegate lcCachedImageLoader:self didLoadImage:image forItem:item wasCacheHit:YES];
} else {
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_BACKGROUND, 0), ^{
NSData *data = [NSData dataWithContentsOfURL:[NSURL URLWithString:urlString]];
UIImage *image = [UIImage imageWithData:data];
dispatch_async(dispatch_get_main_queue(), ^{
[self.cacheStoreDictionary setObject:image forKey:urlString];
[self.delegate lcCachedImageLoader:self didLoadImage:image forItem:item wasCacheHit:NO];
});
});
}
}

我需要的 URL 和其他数据通过 AFNetwork 加载,如下所示:

- (void)fetchTicketEvents
{
// Login URL
NSURL *eventsURL = [NSURL URLWithString:TH_API_BASEURL];

AFHTTPClient *httpClient = [[AFHTTPClient alloc] initWithBaseURL:eventsURL];
httpClient.parameterEncoding = AFJSONParameterEncoding;

// Set request parameters
NSDictionary *params = nil;
NSMutableURLRequest *request = [httpClient requestWithMethod:@"GET"
path:TH_API_PATH_TICKET_EVENT_INDEX
parameters:params];
request.cachePolicy = NSURLRequestReloadIgnoringLocalCacheData;

// Prepare request
AFJSONRequestOperation *eventsRequest = [AFJSONRequestOperation JSONRequestOperationWithRequest:request success:^(NSURLRequest *request, NSHTTPURLResponse *response, id JSON) {
if ([self.delegate respondsToSelector:@selector(thAPITicket:didLoadTicketEvents:response:errorCode:)]) {
NSArray *jsonEventArray = JSON;
NSMutableArray *event = [[NSMutableArray alloc] initWithCapacity:jsonEventArray.count];
for (NSDictionary *eventDictionary in [JSON allObjects]) {
[event addObject:[LCEvent eventFromDictionary:eventDictionary]];
}
[self.delegate thAPITicket:self
didLoadTicketEvents:YES
response:@{@"response" : response, @"json" : JSON, @"event" : event}
errorCode:TH_API_ERR_TICKETINDEX_NO_ERROR];
#if LOG_NETWORKING
[self printJSON:JSON];
#endif
//Network indicator off
[LCSharedInstance hideNetworkActivity];

//Allow Slide-To-Refresh
[LCSharedInstance singletone].allowSlideToRefresh = YES;
[LCSharedInstance singletone].isShownLoadingMessage = NO;
[LCSharedInstance singletone].isLoading = NO;
}
} failure:^(NSURLRequest *request, NSHTTPURLResponse *response, NSError *error, id JSON) {
if ([self.delegate respondsToSelector:@selector(thAPITicket:didLoadTicketEvents:response:errorCode:)]) {
if (nil == JSON) {
JSON = @{};
}
[self.delegate thAPITicket:self
didLoadTicketEvents:NO
response:@{@"response" : response, @"json" : JSON}
errorCode:TH_API_ERR_TICKETINDEX_NO_ERROR];
[LCSharedInstance hideNetworkActivity];

}
//Network indicator off
[LCSharedInstance hideNetworkActivity];
}];
[LCSharedInstance showNetworkActivity];
// Send request
[eventsRequest start];
}

这是我填充 TableViewCell 的方式:

- (void) lcCachedImageLoader:(LCCachedImageLoader *)cachedImageLoader didLoadImage:(UIImage *)teaserImage forItem:(id)item wasCacheHit:(BOOL)wasCacheHit
{
//Teaser Image Implementation
UIImageView *imageView = ((UIImageView*)[((UIView*)item)viewWithTag:100]);
imageView.alpha = 0.2;
imageView.image = teaserImage;
imageView.contentMode = UIViewContentModeScaleToFill;
[UIView animateWithDuration:0.5 animations:^{
imageView.alpha = 1.0;
}];
}


#pragma mark - tableview delegation
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *CellIdentifier = @"offerCell";
LCEvent *event = self.eventArray[indexPath.row];
tableView = self.tableView;
LCClusterViewController *clusterVC = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];

#pragma mark - Cell Config and Style Attributes
clusterVC.titleLabel.attributedText = LCAttrText(event.titleString, LCFontStyleEventName);
clusterVC.ticketDetailsLabel.attributedText = LCAttrText(event.subtitleString, LCFontStyleEventTitle);
clusterVC.oldPriceLabel.attributedText = LCAttrText(event.oldPriceString, LCFontStyleEventOldPrice);
clusterVC.actualPriceLabel.attributedText = LCAttrText(event.actualPriceString, LCFontStyleEventPrice);
clusterVC.timeLabel.attributedText = LCAttrText(event.timeString, LCFontStyleEventInfoText);
clusterVC.ticketCountLabel.attributedText = LCAttrText(event.stockString, LCFontStyleEventInfoText);
clusterVC.dateLabel.attributedText = LCAttrText(event.dateString, LCFontStyleEventDateText);
... and on and on

非常感谢任何有用的提示

最佳答案

出于性能原因,表格 View 单元格被重用,因此如果您在加载图像之前未将其设置为任何内容,它们将保留之前在 UIImageView 中使用的图像。

在调用 startLoadingImageWithUrl 之前,您可以先使用占位符图像设置 imageView 的初始图像,或者在 imageView 顶部添加加载指示器。但请记住在加载真实图像时移除加载指示器。

- (void) startLoadingImageWithUrl:(NSString *)urlString forItem:(id)item
{
UIImageView *imageView = ((UIImageView*)[((UIView*)item)viewWithTag:100]);
imageView.image = placeholderImage;
if (self.cacheStoreDictionary[urlString]) {
UIImage *image = self.cacheStoreDictionary[urlString];
[self.delegate lcCachedImageLoader:self didLoadImage:image forItem:item wasCacheHit:YES];
} else {
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_BACKGROUND, 0), ^{
NSData *data = [NSData dataWithContentsOfURL:[NSURL URLWithString:urlString]];
UIImage *image = [UIImage imageWithData:data];
dispatch_async(dispatch_get_main_queue(), ^{
[self.cacheStoreDictionary setObject:image forKey:urlString];
[self.delegate lcCachedImageLoader:self didLoadImage:image forItem:item wasCacheHit:NO];
});
});
}
}

对于图像加载后出现在错误单元格的图像,这是因为您将重用单元格作为参数传递给 startLoadingImage 和 didLoadImage。尝试改为传递 indexPath 并使用 indexPath 找到正确的单元格,更新单元格 ImageView 。

UITableViewCell *cell = [self.tableView cellForRowAtIndexPath:indexPath];

关于ios - UITableViewCells 中的图像加载错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16686516/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com