Esto me molestó mucho. Estoy tan cerca de implementar mi propio selector de imágenes personalizado usando AssetsLibrary.
Pero mientras tanto, este truco funcionó para mí: estoy mostrando el selector, buscando la vista de desplazamiento en la jerarquía de vista y desplazándola hasta el final, más o menos. Necesita ser animado ya que esto sucede cuando la vista ya está cargada, pero es mejor que el usuario tenga que desplazarse por 5.000 fotos hasta que llegue a las más nuevas.
[self presentViewController:self.imagePickerController animated:YES completion:^() {
// scroll to the end - hack
UIView *imagePickerView = imagePickerController.view;
UIView *view = [imagePickerView hitTest:CGPointMake(5,5) withEvent:nil];
while (![view isKindOfClass:[UIScrollView class]] && view != nil) {
// note: in iOS 5, the hit test view is already the scroll view. I don't want to rely on that though, who knows
// what Apple might do with the ImagePickerController view structure. Searching backwards from the hit view
// should always work though.
//NSLog(@"passing %@", view);
view = [view superview];
}
if ([view isKindOfClass:[UIScrollView class]]) {
//NSLog(@"got a scroller!");
UIScrollView *scrollView = (UIScrollView *) view;
// check what it is scrolled to - this is the location of the initial display - very important as the image picker
// actually slides under the navigation bar, but if there's only a few images we don't want this to happen.
// The initial location is determined by status bar height and nav bar height - just get it from the picker
CGPoint contentOffset = scrollView.contentOffset;
CGFloat y = MAX(contentOffset.y, [scrollView contentSize].height-scrollView.frame.size.height);
CGPoint bottomOffset = CGPointMake(0, y);
[scrollView setContentOffset:bottomOffset animated:YES];
}
}];
que es golpe, simplemente diciendo. gracias hombre. – nickthedude