1

我正在使用 ASIHTTPRequest 将文件本地下载到 iDevice。

我的下载代码如下

ASIHTTPRequest *download = [ASIHTTPRequest requestWithURL: videoUrl];
[download setCompletionBlock:^{            
    NSLog(@"Download Success");        
    // other code
}];
[download setFailedBlock:^{            
    NSLog(@"Download Failed");
    // other code
}];
[download setDownloadProgressDelegate: [item progressDelegate]];
[download startAsynchronous];
NSLog(@"Start Download of %@", [item name]);

该对象item包含对 a 的引用,UIProgressView它显示在屏幕上但从未更新。

在尝试调试时,我对以下日志进行了子类UIProgressView化并添加了以下日志

- (void)setProgress:(float)newProgress {        
  NSLog(@"Current Progress : %f", newProgress);
  [super setProgress: newProgress];
}

我的控制台现在显示从 0.0 到 1.0 的进度,经过约 50 次迭代(很好!),但 uiProgressView 没有改变,最后 NSLog 显示 0.5 是进度视图的默认设置。

有人知道发生了什么吗?

EDIT UIProgressView 用这个访问

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
   UITableViewCell *cell = [tableView cellForRowAtIndexPath: indexPath];
   id progressView = [cell viewWithTag:VideoDetailProgressView];
   [VideoDownloadManager queueDownloadOfVideo:video progressDelegate: progressView];
}

我已经通过并观察它似乎始终保持对 UIProgressView 的正确引用

编辑 TableView 方法

 // Row display. Implementers should *always* try to reuse cells by setting each cell's reuseIdentifier and querying for available reusable cells with dequeueReusableCellWithIdentifier:
 // Cell gets various attributes set automatically based on table (separators) and data source (accessory views, editing controls)
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
static NSString *detailCellIdentifier = @"VideoDetailCell";
static NSString *categoryCellIdentifier = @"VideoCategoryCell";
UITableViewCell *cell = nil;
bool isCategorical = [[self.videoList objectAtIndex: indexPath.row] objectForKey:@"parentName"];


if(isCategorical)
{
    cell = [tableView dequeueReusableCellWithIdentifier:categoryCellIdentifier];
}
else
{
    cell = [tableView dequeueReusableCellWithIdentifier:detailCellIdentifier];
}

if (cell == nil && !isCategorical) {
    [[NSBundle mainBundle] loadNibNamed:@"VideoDetailCell" owner:self options:nil];
    cell = self.videoDetailCell;


    UIImageView *imageView = [[UIImageView alloc] initWithFrame:CGRectMake(5.0, 10.0, 46.0, 46.0)];
    [cell addSubview:imageView];
    imageView.hidden = !self.canEdit;
    imageView.tag = VideoDetailsFavoriteButton;
    [imageView release];        


    self.videoDetailCell = nil;
}
else if(cell == nil && isCategorical)
{
    //Different cell
    cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:categoryCellIdentifier] autorelease];
}
[cell setBackgroundColor:[UIColor clearColor]];
return cell;
}



// Display customization
- (void)tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath {
NSDictionary *object = [self.videoList objectAtIndex:indexPath.row];
bool isCategorical = [[self.videoList objectAtIndex: indexPath.row] objectForKey:@"parentName"];

if(isCategorical) {
    cell.textLabel.textColor = [UIColor whiteColor];
    cell.textLabel.text = [object objectForKey:@"name"];

    NSUInteger videoCount = [[Videos sharedVideos] countById: [object objectForKey:@"name"]];
    cell.detailTextLabel.textColor = [UIColor whiteColor];
    cell.detailTextLabel.text = [NSString stringWithFormat: @"%d videos", videoCount];
}
else
{
    [[cell viewWithTag:VideoDetailCellTitle] setValue:[object objectForKey:@"name"] forKey:@"text"];
    [[cell viewWithTag:VideoDetailCellSubtitle] setValue:[object objectForKey:@"dateAdded"] forKey:@"text"];
    [[cell viewWithTag:VideoDetailCellDuration] setValue:[object objectForKey:@"duration"] forKey:@"text"];

    UIHTTPImageView *asyncImage = (UIHTTPImageView *)[cell viewWithTag:VideoDetailCellImage];
    NSURL *thumbUrl = [NSURL URLWithString:[NSString stringWithFormat: @"%@%@", kRootUrlPath, [object objectForKey:@"image"]]];
    [asyncImage setImageWithURL:thumbUrl placeholderImage: [UIImage imageNamed: kLoadingImage]];
    asyncImage.clipsToBounds = YES;

    UIImageView *editButton = (UIImageView *)[cell viewWithTag:VideoDetailsFavoriteButton];

    if ([VideoDownloadManager isQueued: [object objectForKey: @"name"]]) {
        [[cell viewWithTag:VideoDetailCellSubtitle] setHidden:YES];
        [[cell viewWithTag:VideoDetailProgressView] setHidden:NO];
    } else {
        [[cell viewWithTag:VideoDetailCellSubtitle] setHidden:NO];
        [[cell viewWithTag:VideoDetailProgressView] setHidden:YES];
    }

    if ([VideoDownloadManager isFavorites: [object objectForKey: @"name"]] || [VideoDownloadManager isQueued: [object objectForKey: @"name"]]) {
        editButton.image = [UIImage imageNamed: kFavoritesHighlighted];  
    } else {
        editButton.image = [UIImage imageNamed: kFavoritesEmpty];  
    }

 }
}
4

2 回答 2

0

Can you check if the update is made in the main thread? (it should be the case if you're using the latest version of ASIHTTPRequest)

NSLog(@"Current Progress : %f (main thread=%d)", newProgress, [NSThread isMainThread]);

If it doesn't help, can you show the code that is using the UIProgressView in the view?

于 2012-01-04T17:36:16.037 回答
0

Thanks for everyones help. You guys guided me to then answer. My cell was not correctly being assigned a reuseIdentifier

this was causing the whole issue.

于 2012-01-06T16:34:00.267 回答