iOS如何固定UITableView中cell.imageView.image的圖片大小
前言
凡是進行iOS開發(fā)的,基本上都會遇到要展示列表,或者即使不是標準列表,但由于數(shù)量不固定,也需要如同列表一樣從上往下顯示、加載的情況。這些,都繞不過對UITableView的使用。
在iOS開發(fā)中UITableView可以說是使用最廣泛的控件,我們平時使用的軟件中到處都可以看到它的影子,類似于微信、QQ、新浪微博等軟件基本上隨處都是UITableView。當然它的廣泛使用自然離不開它強大的功能。
我們經(jīng)常在開發(fā)過程中會用到默認UITableView的cell.imageView.image
,如果圖片尺寸剛好跟我們想要的尺寸一樣的話倒也相安無事,但總是有意外的,經(jīng)常從接口獲取的圖片尺寸大小是不固定的
例如下圖1-1:
圖1-1
圖片的尺寸大于cell的高度,所以就被“撐爆”了,顯得非常不美觀、和諧,如果cell的高度不固定,圖片尺寸又不同,那效果就更加難看了,那我們怎么做呢?
你們肯定有多種解決方法了:
1、自定義cell(如果簡單的cell的話這個有點麻煩,又要新建cell文件····)
2、利用UIGraphicsBeginImageContextWithOptions函數(shù)來處理(目前為止我覺得最簡單的方法)
UIImage * icon = [UIImage imageNamed:@"goods_1"]; CGSize itemSize = CGSizeMake(36, 36);//固定圖片大小為36*36 UIGraphicsBeginImageContextWithOptions(itemSize, NO, 0.0);//*1 CGRect imageRect = CGRectMake(0, 0, itemSize.width, itemSize.height); [icon drawInRect:imageRect]; cell.imageView.image = UIGraphicsGetImageFromCurrentImageContext();//*2 UIGraphicsEndImageContext();//*3
完成之后圖示如下圖1-2(是不是瞬間漂亮好多?而且不會嚴重變形哦O(∩_∩)O哈哈~):
圖1-2
這里解釋一下
*1
UIGraphicsBeginImageContextWithOptions(CGSize size, BOOL opaque, CGFloat scale)
這個函數(shù)用于獲取處理圖片的圖形上下文(context),利用該上下文,你就可以在其上進行繪圖,并生成圖片。
- size是創(chuàng)建上下文的大小,同時也是上下文處理圖形后返回的大小
- opaque透明開關,如果圖形完全不用透明,設置為YES以優(yōu)化位圖的存儲。
- scale縮放因子
*2
調用UIGraphicsGetImageFromCurrentImageContext()
函數(shù)可從當前上下文中獲取一個UIImage對象,這樣就講改變了圖片取出來了
*3
在完成對圖片的操作之后要關閉該上下文,所以需要調用UIGraphicsEndImageContext()
函數(shù)
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
iOS端React Native差異化增量更新的實現(xiàn)方法
這篇文章主要給大家介紹了關于iOS端React Native差異化增量更新的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-06-06IOS開發(fā)代碼分享之設置UISearchBar的背景顏色
在項目開發(fā)中,我們經(jīng)常要用到UISearchBar,在網(wǎng)上看到了很多關于去除掉他背景色的方法,都已經(jīng)失效了,今天來分享一個正常使用的方法,希望能幫到大家2014-09-09iOS實現(xiàn)列表與網(wǎng)格兩種視圖的相互切換
相信大家應該也都發(fā)現(xiàn)了,在現(xiàn)在很多的電商app中,都會有列表視圖和網(wǎng)格兩種視圖的相互切換。例如京東和淘寶。這樣更利于提高用戶的體驗度,所以這篇文章小編就是大家分享下利用iOS實現(xiàn)列表與網(wǎng)格兩種視圖相互切換的方法,文中介紹的很詳細,感興趣的下面來一起看看吧。2016-10-10