Добавление UIActivityIndicator в модальное представление (ELCimagepicker) - PullRequest
3 голосов
/ 28 мая 2011

Я добавил ELCimagepicker (https://github.com/Fingertips/ELCImagePickerController) в мой проект, и он отлично работает, позволяя пользователю выбрать несколько изображений для слайд-шоу. Но когда вы нажимаете «Сохранить», может возникнуть длительная задержка в зависимости от того, сколько фотографии были добавлены.

Я пытался добавить UIActivityIndicator, когда пользователь нажимает «Сохранить», но у меня возникли проблемы из-за представленного модального представления. Я могу вызвать метод из действия, которое представляет ELCimagepicker (ELCImagePickerController), и это действие выполняется действием, обрабатывающим представление средства выбора изображений. Но всякий раз, когда я пытаюсь добавить его в представление, оно не отображается, поскольку модальное меню находится сверху индикатора активности.

Я пытался использовать метод takeSubviewToFront, пытался добавить код непосредственно в файл метода imagepicker с помощью [[self parentViewController] addSubView], но безуспешно.

Вот последний код, который я пробовал: (индикатор объявлен в файле .h как индикатор UIActivityIndicator *)

 indicator = [[UIActivityIndicatorView alloc]initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
indicator.hidden=false;

[self.navigationController.view addSubview:self.indicator];
[self.navigationController.view bringSubviewToFront:self.indicator];

[indicator startAnimating];

if([delegate respondsToSelector:@selector(elcImagePickerController:showIndicator:)]) {
    [delegate performSelector:@selector(elcImagePickerController:showIndicator:) withObject:self withObject:@"test"];
}

У кого-нибудь был успех с добавлением UIActivityIndicator поверх ELCimagepicker или другого модального представления, обрабатываемого другим классом?

Я пробовал MBProgressHUD, но не смог заставить его работать совершенно правильно - он отобразился бы, когда я использовал его в классе ELCimagepicker, но потерпел крах при удалении с:

bool _WebTryThreadLock(bool), 0x42368e0: Tried to obtain the web lock from a thread other than the main thread or the web thread. This may be a result of calling to UIKit from a secondary thread. Crashing now...

Любая помощь была бы фантастической.

Спасибо.

Ответы [ 3 ]

4 голосов
/ 24 ноября 2011

Я должен выяснить вашу проблему. Вы можете сделать это, как показано ниже ..

-(void)selectedAssets:(NSArray*)_assets {

UIActivityIndicatorView * activityIndicator = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
UIViewController * topView = [self.viewControllers objectAtIndex:[self.viewControllers count]-1];
activityIndicator.center = CGPointMake(topView.view.frame.size.width/2, topView.view.frame.size.height/2);
[activityIndicator setHidden:NO];
[topView.view addSubview:activityIndicator];
[topView.view bringSubviewToFront:activityIndicator];
[activityIndicator startAnimating];

[self performSelector:@selector(doProcess:) withObject:_assets afterDelay:2.1];

}

- (void) doProcess:(NSArray *)_assets {

NSMutableArray *returnArray = [[[NSMutableArray alloc] init] autorelease];

for(ALAsset *asset in _assets) {

    NSMutableDictionary *workingDictionary = [[NSMutableDictionary alloc] init];
    [workingDictionary setObject:[asset valueForProperty:ALAssetPropertyType] forKey:@"UIImagePickerControllerMediaType"];
    [workingDictionary setObject:[UIImage imageWithCGImage:[[asset defaultRepresentation] fullScreenImage]] forKey:@"UIImagePickerControllerOriginalImage"];
    [workingDictionary setObject:[[asset valueForProperty:ALAssetPropertyURLs] valueForKey:[[[asset valueForProperty:ALAssetPropertyURLs] allKeys] objectAtIndex:0]] forKey:@"UIImagePickerControllerReferenceURL"];

    [returnArray addObject:workingDictionary];

    [workingDictionary release];    
}

[self popToRootViewControllerAnimated:NO];
[[self parentViewController] dismissModalViewControllerAnimated:YES];

if([delegate respondsToSelector:@selector(elcImagePickerController:didFinishPickingMediaWithInfo:)]) {
    [delegate performSelector:@selector(elcImagePickerController:didFinishPickingMediaWithInfo:) withObject:self withObject:[NSArray arrayWithArray:returnArray]];
}

}

Дайте мне знать, если этот ответ поможет вам ...

Спасибо, MinuMaster

1 голос
/ 28 мая 2011

Похоже, вы обновляете пользовательский интерфейс в фоновом потоке. Все обновления UIKit должны быть сделаны в главном потоке. Поэтому я рекомендую вам выполнять методы для обновления пользовательского интерфейса, используя performSelectorOnMainThread:withObject:.

0 голосов
/ 16 сентября 2014

Я решил проблему следующим образом

     activityIndicatorObject = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleWhiteLarge];

     // Set Center Position for ActivityIndicator

     activityIndicatorObject.center = CGPointMake(150, 250);
     activityIndicatorObject.backgroundColor=[UIColor grayColor];

     // Add ActivityIndicator to your view
     [self.view addSubview:activityIndicatorObject];

     activityIndicatorObject.hidesWhenStopped=NO;

     [activityIndicatorObject startAnimating];
...