Jestem całkiem nowy w Objective-C, więc mam nadzieję, że to wszystko ma sens. Pobrałem obrazy z serwera i wyświetlono je w widoku obrazu w metodzie collectionView cellForItemAtIndexPath:
. Problem, który napotykam, polega na tym, że obrazy nie są buforowane. Wygląda na to, że za każdym razem, gdy komórka jest ponownie wykorzystywana, powiązany obraz z serwera jest ponownie pobierany.Buforowanie obrazu i UICollectionView
W mojej metody viewDidLoad Tworzę NSMutableDictionary:
imageDictionary = [[NSMutableDictionary alloc]initWithCapacity:50.0];
Od czytanie dokumentacji i patrząc na odpowiedzi na podobne pytania myślałem, że to plus Poniższy kod wystarczy. Byłem w tym od kilku dni i wiem, że jest coś, czego mi brakuje lub koncepcja, której nie chwytam.
#pragma mark - UICollectionView Data Source
- (NSInteger)collectionView:(UICollectionView *)view numberOfItemsInSection:(NSInteger)section;{
NSLog(@"Begin retrieving photos");
return [self.photos count];
}
-(NSInteger)numberOfSectionsInCollectionView:(UICollectionView *)collectionView{
return 1;
}
- (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath;{
CollectionViewCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:@"MY_CELL" forIndexPath:indexPath];
cell.imageView.image = nil;
if (cell.imageView.image == nil) {
dispatch_queue_t downloadQueue = dispatch_queue_create("image downloader", NULL);
dispatch_async(downloadQueue, ^{
NSData *data = [NSData dataWithContentsOfURL:[NSURL URLWithString:[[self.photos objectAtIndex:indexPath.row] objectForKey:@"fullimage"]]];
UIImage *image = [UIImage imageWithData:data];
[imageDictionary setObject:image forKey:@"Image"];
dispatch_async(dispatch_get_main_queue(), ^{
cell.imageView.image = [imageDictionary objectForKey:@"Image"];
[cell setNeedsDisplay];
});
});
}
return cell;
}
Każda pomoc zostanie bardzo doceniona. Z góry dziękuję.
Wygląda na to, że ponownie pobierasz obraz za każdym razem. Widok kolekcji nie buforuje obrazów dla Ciebie. Musisz utworzyć własny słownik pamięci podręcznej. Zajrzyj do NSCache. – yuf
@yuf zrobię - dzięki! – BrianS