ios中攝像頭/相冊(cè)獲取圖片,壓縮圖片,上傳服務(wù)器方法總結(jié)

字號(hào):


    這幾天在搞iphone上面一個(gè)應(yīng)用的開發(fā),里面有需要攝像頭/相冊(cè)編程和圖片上傳的問(wèn)題,在這里總結(jié)一下。
    【部分知識(shí)】
    iphone中圖像通常存儲(chǔ)在4個(gè)地方【相冊(cè)、應(yīng)用程序包、沙盒、Internet】,通過(guò)這4個(gè)源,我們就可以存取應(yīng)用圖片。
    相冊(cè)
    iphone的相冊(cè)包含攝像頭膠卷+用戶計(jì)算機(jī)同步的部分照片。用戶可以通過(guò)UIImagePickerController類提供的交互對(duì)話框來(lái)從相冊(cè)中選擇圖像。但是,注意:相冊(cè)中的圖片機(jī)器路徑無(wú)法直接從應(yīng)用程序訪問(wèn),只能通過(guò)終端用戶去選擇和使用相冊(cè)圖片
    應(yīng)用程序包
    應(yīng)用程序包可能會(huì)將圖像與可執(zhí)行程序、Info.plist文件和其他資源一同存儲(chǔ)。我們可以通過(guò)本地文件路徑來(lái)讀取這些基于包的圖像并在應(yīng)用程序中顯示它們。
    沙盒
    借助沙盒,我們可以把圖片存儲(chǔ)到Documents、Library、tmp文件夾中。這些文件均可有應(yīng)用程序讀取,且可以通過(guò)文件路徑創(chuàng)建圖像。盡管沙盒外的部分從技術(shù)上說(shuō)是可行的,但是apple表明這些部分不在appstore應(yīng)用程序允許訪問(wèn)的范圍之內(nèi)。
    Internet
    應(yīng)用程序可以通過(guò)圖片的URL來(lái)訪問(wèn)Internet上的資源。
    以上為一些小知識(shí),來(lái)自《iphone開發(fā)秘籍(第二版)》,可以自己去參考此書。
    下面開始切入正題,從攝像頭/相冊(cè)獲取圖片,壓縮圖片,上傳圖片。
    從攝像頭/相冊(cè)獲取圖片
    剛剛在上面的知識(shí)中提到從攝像頭/相冊(cè)獲取圖片是面向終端用戶的,由用戶去瀏覽并選擇圖片為程序使用。在這里,我們需要過(guò)UIImagePickerController類來(lái)和用戶交互。
    使用UIImagePickerController和用戶交互,我們需要實(shí)現(xiàn)2個(gè)協(xié)議。
    View Code
    代碼如下:
    #pragma mark 從用戶相冊(cè)獲取活動(dòng)圖片
    - (void)pickImageFromAlbum
    {
    imagePicker = [[UIImagePickerController alloc] init];
    imagePicker.delegate = self;
    imagePicker.sourceType = UIImagePickerControllerSourceTypePhotoLibrary;
    imagePicker.modalTransitionStyle = UIModalTransitionStyleCoverVertical;
    imagePicker.allowsEditing = YES;
    [self presentModalViewController:imagePicker animated:YES];
    }
    我們來(lái)看看上面的從相冊(cè)獲取圖片,我們首先要實(shí)例化UIImagePickerController對(duì)象,然后設(shè)置imagePicker對(duì)象為當(dāng)前對(duì)象,設(shè)置imagePicker的圖片來(lái)源為UIImagePickerControllerSourceTypePhotoLibrary,表明當(dāng)前圖片的來(lái)源為相冊(cè),除此之外還可以設(shè)置用戶對(duì)圖片是否可編輯。
    View Code
    代碼如下:
    #pragma mark 從攝像頭獲取活動(dòng)圖片
    - (void)pickImageFromCamera
    {
    imagePicker = [[UIImagePickerController alloc] init];
    imagePicker.delegate = self;
    imagePicker.sourceType = UIImagePickerControllerSourceTypeCamera;
    imagePicker.modalTransitionStyle = UIModalTransitionStyleCoverVertical;
    imagePicker.allowsEditing = YES;
    [self presentModalViewController:imagePicker animated:YES];
    }
    以上是從攝像頭獲取圖片,和從相冊(cè)獲取圖片只是圖片來(lái)源的設(shè)置不一樣,攝像頭圖片的來(lái)源為UIImagePickerControllerSourceTypeCamera。
    在和用戶交互之后,用戶選擇好圖片后,會(huì)回調(diào)選擇結(jié)束的方法。
    View Code
    代碼如下:
    - (void) imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info
    {
    UIImage *image= [info objectForKey:@"UIImagePickerControllerOriginalImage"];
    if (picker.sourceType == UIImagePickerControllerSourceTypeCamera)
    {
    // UIImageWriteToSavedPhotosAlbum(image, nil, nil, nil);
    }
    theImage = [UtilMethod imageWithImageSimple:image scaledToSize:CGSizeMake(120.0, 120.0)];
    UIImage *midImage = [UtilMethod imageWithImageSimple:image scaledToSize:CGSizeMake(210.0, 210.0)];
    UIImage *bigImage = [UtilMethod imageWithImageSimple:image scaledToSize:CGSizeMake(440.0, 440.0)];
    [theImage retain];
    [self saveImage:theImage WithName:@"salesImageSmall.jpg"];
    [self saveImage:midImage WithName:@"salesImageMid.jpg"];
    [self saveImage:bigImage WithName:@"salesImageBig.jpg"];
    [self dismissModalViewControllerAnimated:YES];
    [self refreshData];
    [picker release];
    }
    在回調(diào)結(jié)束的方法中,我們對(duì)圖片進(jìn)行了大小的處理,為圖片的上傳做準(zhǔn)備。
    縮放圖片
    縮放圖片比較簡(jiǎn)單,就直接放上代碼,讓大家參考一下。
    View Code
    代碼如下:
    //壓縮圖片
    + (UIImage*)imageWithImageSimple:(UIImage*)image scaledToSize:(CGSize)newSize
    {
    // Create a graphics image context
    UIGraphicsBeginImageContext(newSize);
    // Tell the old image to draw in this new context, with the desired
    // new size
    [image drawInRect:CGRectMake(0,0,newSize.width,newSize.height)];
    // Get the new image from the context
    UIImage* newImage = UIGraphicsGetImageFromCurrentImageContext();
    // End the context
    UIGraphicsEndImageContext();
    // Return the new image.
    return newImage;
    }
    存儲(chǔ)圖像
    在上面我們獲取到了圖片并對(duì)圖片進(jìn)行了壓縮,通過(guò)之前的小知識(shí)了解到,將應(yīng)用需要的一些圖片存入沙盒是個(gè)不錯(cuò)的選擇,而且應(yīng)用程序可以直接通過(guò)路徑去方法沙盒中的圖片,在這里我們將圖片存入沙盒中的Documents目錄下。
    View Code
    代碼如下:
    #pragma mark 保存圖片到document
    - (void)saveImage:(UIImage *)tempImage WithName:(NSString *)imageName
    {
    NSData* imageData = UIImagePNGRepresentation(tempImage);
    NSArray* paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    NSString* documentsDirectory = [paths objectAtIndex:0];
    // Now we get the full path to the file
    NSString* fullPathToFile = [documentsDirectory stringByAppendingPathComponent:imageName];
    // and then we write it out
    [imageData writeToFile:fullPathToFile atomically:NO];
    }
    從Documents目錄下獲取圖片
    要從Documents下面獲取圖片,我們首先需要獲取Documents目錄的路徑。
    View Code
    代碼如下:
    #pragma mark 從文檔目錄下獲取Documents路徑
    - (NSString *)documentFolderPath
    {
    return [NSHomeDirectory() stringByAppendingPathComponent:@"Documents"];
    }
    然后,我們便可以通過(guò)文件名,去訪問(wèn)獲取資源了。
    View Code
    上傳圖片
    項(xiàng)目中我們使用了ASIFormHttpRequest的開源框架,http請(qǐng)求的部分代碼如下,http返回以及相關(guān)回調(diào)方法略去。
    View Code
    代碼如下:
    - (void)upLoadSalesBigImage:(NSString *)bigImage MidImage:(NSString *)midImage SmallImage:(NSString *)smallImage
    {
    NSURL *url = [NSURL URLWithString:UPLOAD_SERVER_URL];
    ASIFormDataRequest *request = [ASIFormDataRequest requestWithURL:url];
    [request setPostValue:@"photo" forKey:@"type"];
    [request setFile:bigImage forKey:@"file_pic_big"];
    [request buildPostBody];
    [request setDelegate:self];
    [request setTimeOutSeconds:TIME_OUT_SECONDS];
    [request startAsynchronous];
    }