簡單圖片瀏覽器

九宮格圖片瀏覽

思路:

1.放大

計算得到當前點擊的imageView在windows的frame,

創(chuàng)建一個新的imageView在windows上并設置frame放椰,根據(jù)image的寬高比計算出全屏顯示時的高度和y值

動畫放大

2.添加輪播圖

移除windos上的imageView

創(chuàng)建添加scrollView在windows上刑然,設置contentOffset.x(第幾個imageView*屏幕寬度)寺擂,根據(jù)傳入的數(shù)組個數(shù)創(chuàng)建imageView,如果是長圖的話要先創(chuàng)建一個scrollView再在上面創(chuàng)建一個imageView。

3.縮小

創(chuàng)建一個新的imageView在windows上計算frame

移除scrollView

動畫縮小后移除imageView


使用:

row點擊第幾個圖片(從0開始)怔软,array是image view的數(shù)組

PhotoBrowser.h文件

#importtypedef void(^photoBrowserBlock)();

@interface PhotoBrowser : UIView

- (void)didSelectImageItem:(NSInteger)item andArray:(NSArray *)array;

@property (nonatomic ,copy) photoBrowserBlock block;

@end

PhotoBrowser.m文件

#import "PhotoBrowser.h"@interface? PhotoBrowser ()@end

@implementation PhotoBrowser

{

//當前頁碼

UILabel *pageLabel;

}

#define Alpha 0.85

- (void)didSelectImageItem:(NSInteger)item andArray:(NSArray *)array {

//遮蓋

UIView *cover = [[UIView alloc]initWithFrame:self.bounds];

cover.backgroundColor = COLOR_Black;

cover.alpha = 0;

[self addSubview:cover];

//1.在windows創(chuàng)建一個新的imageView,設置frame

UIImageView *imageView = [[UIImageView alloc]initWithFrame:[self returnCGRect:array[item]]];

imageView.image = [(UIImageView*)array[item] image];

imageView.contentMode = UIViewContentModeScaleAspectFill;

imageView.layer.masksToBounds = YES;

[self addSubview:imageView];

//計算image的size

CGSize size = [self returnImageSize:imageView.image];

//計算imageView全屏顯示時的高度

NSInteger h = WIDTH*size.height/size.width;

[UIView animateWithDuration:0.5 animations:^{

if (size.width/size.height >= WIDTH/HEIGHT) {

//寬圖時y值

NSInteger y = (HEIGHT/2 - h/2);

//動畫放大寬圖

imageView.frame = CGRectMake(0, y, WIDTH, h);

cover.alpha = Alpha;

}

else {

//動畫放大長圖

imageView.frame = CGRectMake(0, 0, WIDTH, h);

cover.alpha = Alpha;

}

}

completion:^(BOOL finished) {

//移除windos上的imageView

[imageView removeFromSuperview];

//創(chuàng)建添加scrollView

[self setScrollItem:item andArray:array ];

}];

//頁碼顯示

UILabel *label = [[UILabel alloc]initWithFrame:CGRectMake(WIDTH/2, HEIGHT-50, WIDTH, 20)];

label.text = [NSString stringWithFormat:@"/%ld",array.count];

label.textColor = COLOR_While;

label.textAlignment = NSTextAlignmentLeft;

[self addSubview:label];

pageLabel = [[UILabel alloc]initWithFrame:CGRectMake(0, HEIGHT-50, WIDTH/2, 20)];

pageLabel.text = [NSString stringWithFormat:@"%ld",item+1];

pageLabel.textColor = COLOR_While;

pageLabel.textAlignment = NSTextAlignmentRight;

[self addSubview:pageLabel];

}

- (void)setScrollItem:(NSInteger)item andArray:(NSArray *)array {

//2.創(chuàng)建scrollView

UIImageView *imv=[[UIImageView alloc]init];

imv.tag = i+1;

imv.contentMode = UIViewContentModeScaleAspectFit;

imv.image=[(UIImageView*)array[i] image];

imv.userInteractionEnabled=YES;

//計算image的size

CGSize size = [self returnImageSize:[(UIImageView*)array[i] image]];

if (size.width/size.height < WIDTH/HEIGHT) {

//展示長圖

UIScrollView *scrollView = [[UIScrollView alloc] initWithFrame:CGRectMake(x, 0, WIDTH, HEIGHT)];

[scroll addSubview:scrollView];

//計算高度

NSInteger h = WIDTH*size.height/size.width;

imv.frame =CGRectMake(0, 0, WIDTH, h);

scrollView.contentSize = imv.frame.size;

scrollView.showsHorizontalScrollIndicator = NO;

scrollView.showsVerticalScrollIndicator = NO;

[scrollView addSubview:imv];

}

else {

imv.frame = CGRectMake(x, 0, WIDTH, HEIGHT);

[scroll addSubview:imv];

}

//3.縮小

[imv whenTapped:^{

UIView *cover = [[UIView alloc]initWithFrame:self.bounds];

cover.backgroundColor = COLOR_Black;

cover.alpha = Alpha;

[WINDOWS_View addSubview:cover];

//計算image全屏顯示時的高度

NSInteger h = WIDTH*size.height/size.width;

//y值

NSInteger y = (HEIGHT/2 - h/2);

//創(chuàng)建一個新的imageView在windows上計算frame

UIImageView *imageview = [[UIImageView alloc]init];

if (size.width/size.height < WIDTH/HEIGHT)

imageview.frame = CGRectMake(0, 0, WIDTH, h);

else

imageview.frame = CGRectMake(0, y, WIDTH, h);

imageview.image = imv.image;

imageview.contentMode = UIViewContentModeScaleAspectFill;

imageview.layer.masksToBounds = YES;

[WINDOWS_View addSubview:imageview];

//移除scrollView

[scroll removeFromSuperview];

//回調(diào)

self.block();

//動畫縮小后移除imageView

[UIView animateWithDuration:0.5 animations:^{

imageview.frame = [self returnCGRect:array[imv.tag-1]];

cover.alpha = 0;

} completion:^(BOOL finished) {

[imageview removeFromSuperview];

[cover removeFromSuperview];

}];

}];

}

}

- (void)scrollViewDidScroll:(UIScrollView *)scrollView

{

int page = scrollView.contentOffset.x / scrollView.frame.size.width;

pageLabel.text = [NSString stringWithFormat:@"%d",page+1];

}

//返回imageView在windows的frame

- (CGRect )returnCGRect:(UIImageView *)imageView {

return [imageView convertRect: imageView.bounds toView:WINDOWS];

}

//返回image的size

- (CGSize)returnImageSize:(UIImage*)image {

CGImageRef imageRef = [image CGImage];

return? CGSizeMake(CGImageGetWidth(imageRef), CGImageGetHeight(imageRef));

}

@end

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末垦细,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子挡逼,更是在濱河造成了極大的恐慌括改,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,695評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件家坎,死亡現(xiàn)場離奇詭異嘱能,居然都是意外死亡,警方通過查閱死者的電腦和手機乘盖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評論 3 399
  • 文/潘曉璐 我一進店門焰檩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人订框,你說我怎么就攤上這事析苫。” “怎么了穿扳?”我有些...
    開封第一講書人閱讀 168,130評論 0 360
  • 文/不壞的土叔 我叫張陵衩侥,是天一觀的道長。 經(jīng)常有香客問我矛物,道長茫死,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,648評論 1 297
  • 正文 為了忘掉前任履羞,我火速辦了婚禮峦萎,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘忆首。我一直安慰自己爱榔,他們只是感情好,可當我...
    茶點故事閱讀 68,655評論 6 397
  • 文/花漫 我一把揭開白布糙及。 她就那樣靜靜地躺著详幽,像睡著了一般。 火紅的嫁衣襯著肌膚如雪浸锨。 梳的紋絲不亂的頭發(fā)上唇聘,一...
    開封第一講書人閱讀 52,268評論 1 309
  • 那天,我揣著相機與錄音柱搜,去河邊找鬼迟郎。 笑死,一個胖子當著我的面吹牛聪蘸,可吹牛的內(nèi)容都是我干的宪肖。 我是一名探鬼主播炒嘲,決...
    沈念sama閱讀 40,835評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼匈庭!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起浑劳,我...
    開封第一講書人閱讀 39,740評論 0 276
  • 序言:老撾萬榮一對情侶失蹤阱持,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后魔熏,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體衷咽,經(jīng)...
    沈念sama閱讀 46,286評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,375評論 3 340
  • 正文 我和宋清朗相戀三年蒜绽,在試婚紗的時候發(fā)現(xiàn)自己被綠了镶骗。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,505評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡躲雅,死狀恐怖鼎姊,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情相赁,我是刑警寧澤相寇,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站钮科,受9級特大地震影響唤衫,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜绵脯,卻給世界環(huán)境...
    茶點故事閱讀 41,873評論 3 333
  • 文/蒙蒙 一佳励、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蛆挫,春花似錦赃承、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至畜挨,卻和暖如春筒繁,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背巴元。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評論 1 272
  • 我被黑心中介騙來泰國打工毡咏, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人逮刨。 一個月前我還...
    沈念sama閱讀 48,921評論 3 376
  • 正文 我出身青樓呕缭,卻偏偏與公主長得像堵泽,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子恢总,可洞房花燭夜當晚...
    茶點故事閱讀 45,515評論 2 359

推薦閱讀更多精彩內(nèi)容