成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

淺析在iPhone下實(shí)現(xiàn)UIScrollView圖片瀏覽器功能

移動(dòng)開(kāi)發(fā) iOS
本文主要介紹了在iPhone下實(shí)現(xiàn)ScrollView圖片瀏覽器的實(shí)例,功能很簡(jiǎn)單,來(lái)看詳細(xì)內(nèi)容。

iPhoneUIScrollView圖片瀏覽器是本文要介紹的內(nèi)容,今天看書(shū)中介紹了從圖片庫(kù)中調(diào)用圖片的例子,一時(shí)性起打算做一個(gè)簡(jiǎn)單的圖片瀏覽器。

功能很簡(jiǎn)單,從圖片庫(kù)中載入圖片,然后放到view下,并支持放大,縮小,平移。

由于對(duì)控件庫(kù)不了解,一開(kāi)始的方案是這樣的:

前面的框架都一樣:

用toolbar做按鈕條,里面有個(gè)按鍵,觸發(fā)從按鍵。

按鍵action調(diào)用圖片庫(kù),之后圖片庫(kù)發(fā)消息到delegate(我這里協(xié)議掛在了主UIViewController上面,后面其他的delegate也一樣)。

如果正確得到了圖片 UIImagePickerControllerDelegate的imagePickerController:didFinishPickingMediaWithInfo:的第二個(gè)參數(shù)可以得到一個(gè)包含選定圖片的Dictionary。

OK,演出開(kāi)始了。后面的方案是這樣。

1、搞了個(gè)UIImageView作為圖片載體,撲滿整個(gè)屏幕,然后將Mode設(shè)置為Center,圖片設(shè)置后可以居中顯示。

然后利用UIPinchGestureRecognizer做手勢(shì),手勢(shì)觸發(fā)后會(huì)回調(diào)響應(yīng)方法。在方法中設(shè)置UIImageView的bounds和center保證其居中顯示。過(guò)程中從網(wǎng)絡(luò)上搜索了一個(gè)擴(kuò)展UIImage的類(lèi)型,可以進(jìn)行縮放圖片。源碼:(注意,這個(gè)函數(shù)由于用到了UIGraphicsXXXX函數(shù),要求只能再主線程中調(diào)用)

  1. //  
  2. //  UIImage_Extra.h  
  3. //  Camera  
  4. //  
  5. //  Created by 李 擇一 on 11-4-22.  
  6. //  Copyright 2011 __MyCompanyName__. All rights reserved.  
  7. //  
  8. #import <Foundation/Foundation.h> 
  9. @interface UIImage (Extra)  
  10. - (UIImage*) imageByScalingAndCroppingForSize: (CGSize)targetSize;  
  11. @end  
  12. //  
  13. //  UIImage_Extra.m  
  14. //  Camera  
  15. //  
  16. //  Created by 李 擇一 on 11-4-22.  
  17. //  Copyright 2011 __MyCompanyName__. All rights reserved.  
  18. //  
  19. #import "UIImage_Extra.h"  
  20. @implementation UIImage (Extra)  
  21. - (UIImage*)imageByScalingAndCroppingForSize: (CGSize)targetSize  
  22. {  
  23.     UIImage *sourceImage = self;  
  24.     UIImage *newImage = nil;          
  25.     CGSize imageSize = sourceImage.size;  
  26.     CGFloat width = imageSize.width;  
  27.     CGFloat height = imageSize.height;  
  28.     CGFloat targetWidth = targetSize.width;  
  29.     CGFloat targetHeight = targetSize.height;  
  30.     CGFloat scaleFactor = 0.0;  
  31.     CGFloat scaledWidth = targetWidth;  
  32.     CGFloat scaledHeight = targetHeight;  
  33.     CGPoint thumbnailPoint = CGPointMake(0.0,0.0);  
  34.     if (CGSizeEqualToSize(imageSize, targetSize) == NO)   
  35.     {  
  36.         CGFloat widthFactor = targetWidth / width;  
  37.         CGFloat heightFactor = targetHeight / height;  
  38.         if (widthFactor > heightFactor)   
  39.             scaleFactor = widthFactor; // scale to fit height  
  40.         else  
  41.       scaleFactor = heightFactor; // scale to fit width  
  42.         scaledWidth  = width * scaleFactor;  
  43.         scaledHeight = height * scaleFactor;  
  44.         // center the image  
  45.         if (widthFactor > heightFactor)  
  46.         {  
  47.             thumbnailPoint.y = (targetHeight - scaledHeight) * 0.5;   
  48.         }  
  49.         else   
  50.             if (widthFactor < heightFactor)  
  51.             {  
  52.                 thumbnailPoint.x = (targetWidth - scaledWidth) * 0.5;  
  53.             }  
  54.     }         
  55.     UIGraphicsBeginImageContext(targetSize); // this will crop  
  56.     CGRect thumbnailRect = CGRectZero;  
  57.     thumbnailRect.origin = thumbnailPoint;  
  58.     thumbnailRect.size.width  = scaledWidth;  
  59.     thumbnailRect.size.height = scaledHeight;    
  60.     [sourceImage drawInRect:thumbnailRect];  
  61.     newImage = UIGraphicsGetImageFromCurrentImageContext();  
  62.     if(newImage == nil)   
  63.         NSLog(@"could not scale image");  
  64.     //pop the context to get back to the default  
  65.     UIGraphicsEndImageContext();  
  66.     return newImage;  
  67. }  
  68. @end 

再往下做平移的時(shí)候出現(xiàn)了問(wèn)題,雖然可以重載touchesBegan和touchesMove移動(dòng)UIImageView,可是就失去了iOS特效了,并且當(dāng)圖片移到屏幕邊緣再進(jìn)行放大,縮小,UIImageView就不一定飛到那里去了,還需要繼續(xù)增加判斷條件。所以此方法不可取。

現(xiàn)在發(fā)現(xiàn)了新的api可以解決拉伸的問(wèn)題。在UIImage 中有個(gè)函數(shù)叫stretchableImageWithLeftCapWidth:topCapHeight:的,可以返回一個(gè)新的UIImage,這個(gè)UIImage是可以拉伸的。具體用法請(qǐng)參閱apple的Sample Code.

2、到網(wǎng)上查了可以利用UIScrollView做平移處理,在其中嵌入一個(gè)UIImageView,手勢(shì)用來(lái)管理圖片放大縮小,這樣就可以一邊吃火鍋,一邊唱歌了。

這個(gè)方案要考慮的事情有幾個(gè),一個(gè)是UIScrollView的contentSize的要考慮UIImageView的大小,在放大或者縮小圖片以后要調(diào)整contentSize的大小。

還有一個(gè)就是在縮放的時(shí)候要考慮到,縮放的中心位置問(wèn)題。比如,現(xiàn)在圖片上有個(gè)人臉,然后手勢(shì)是以人臉鼻子為中心放大的,在放大結(jié)束后,可能手勢(shì)的中心就跑偏了,因此要在縮放時(shí)修改UIImageView的center,這個(gè)計(jì)算還是挺復(fù)雜的。

3、為了解決這個(gè)問(wèn)題繼續(xù)搜索文檔,發(fā)現(xiàn)在UIScrollView里面有zoom這個(gè)東東,可以通過(guò)delegate的viewForZoomingInScrollView:方法指定UIScrollView中的某個(gè)view放大,還可以設(shè)定放大的最大倍數(shù)和最小倍數(shù)。這個(gè)nb了,一個(gè)UIScrollView類(lèi)全都搞定了平移縮放??岚。?!

但是這個(gè)也有要注意的問(wèn)題。由于UIScrollView里面可能要主動(dòng)調(diào)用他所包含subView的屬性,因此在縮放過(guò)程中,不要修改subview的屬性。

另外,縮放平移全都人家搞了,在給UIImageView中換圖片之前一定要注意先將UIScrollView的zoomScale,contentSize,contentOffset全都設(shè)置成初始值。設(shè)想這樣一個(gè)情況,在UIScrollView里面將圖片放大,contentSize,contentOffset,zoomScale全變了,而你這時(shí)候找了個(gè)特小的圖片放進(jìn)來(lái),如果不設(shè)置那三個(gè)屬性的初值,或者只設(shè)置了一個(gè),這樣必然會(huì)造成混亂。

三種方法里還是第三種最簡(jiǎn)單啊。

總結(jié):我忘了那本書(shū)里面說(shuō)過(guò),Apple公司為在Mac上面的工作做了20年,如果你需要用很多代碼實(shí)現(xiàn)一個(gè)很簡(jiǎn)單的功能,肯定是方法不對(duì)。

今天的探索印證了這句話。還有,現(xiàn)在市面上所有的iOS開(kāi)發(fā)書(shū)籍里都沒(méi)有原理層面的講解開(kāi)發(fā)的。所以搜索引擎,加上瀏覽各種網(wǎng)站論壇成為解決問(wèn)題的快捷途徑。

小結(jié):淺析在iPhone下實(shí)現(xiàn)ScrollView圖片瀏覽器功能的內(nèi)容介紹完了,希望本文對(duì)你有所幫助。

責(zé)任編輯:zhaolei 來(lái)源: 博客園
相關(guān)推薦

2009-09-04 09:27:48

C#調(diào)用瀏覽器

2011-02-23 10:57:27

Konqueror

2011-04-25 12:49:32

iPad2瀏覽器

2009-09-04 10:05:16

C#調(diào)用瀏覽器瀏覽器的原理

2009-09-14 09:56:09

Linux應(yīng)用Fedoraopera瀏覽器

2009-09-03 17:49:59

C#瀏覽器開(kāi)發(fā)

2009-09-03 17:54:04

C#開(kāi)發(fā)瀏覽器

2023-11-07 09:32:56

Edge瀏覽器

2012-09-11 15:10:28

傲游瀏覽器

2012-12-06 14:34:16

2009-06-04 09:20:45

2021-06-08 15:13:45

Safari瀏覽器擴(kuò)展

2012-09-06 10:05:03

Windows 8瀏覽器

2011-08-05 10:17:02

Chrome瀏覽器

2011-09-15 16:33:25

2012-10-09 15:28:06

2009-04-25 09:29:29

iPhone手機(jī)瀏覽器Andorid

2012-06-18 14:57:45

傲游瀏覽器iPhone

2012-11-06 11:37:26

傲游瀏覽器

2020-12-17 11:08:20

Safari手機(jī)瀏覽器蘋(píng)果
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 国产精品美女久久久av超清 | 黄色国产视频 | 欧美日韩1区 | 欧美一区二区三区大片 | 亚洲逼院 | 三级黄色片在线播放 | 天天av网| 国产精品18hdxxxⅹ在线 | 99精品免费 | 黄色一级毛片 | 国产日韩欧美精品一区二区 | 男女免费在线观看视频 | 久久久久久综合 | 男女爱爱福利视频 | 亚洲精品大片 | 免费成人高清在线视频 | 欧美lesbianxxxxhd视频社区 | 色综合99 | 国产精品成人一区二区三区吃奶 | 欧美日本韩国一区二区 | 91久久久久久 | 中文字幕高清 | 午夜精品91 | 天天爽网站 | 精品国产一区二区三区久久久蜜月 | 欧美一区2区三区3区公司 | 日韩中文字幕一区二区三区 | 国产精品一区二区在线 | www久久久| 久久久久久久一区二区三区 | 91视频免费在观看 | av网站推荐| 国产一区二区精华 | 天天操网| 日韩免费在线视频 | 日韩精品a在线观看图片 | 国产精品久久久久久久久久 | 丝袜美腿一区二区三区 | 天天干天天干 | 在线亚洲免费 | 成人久久网 |