關於UIImageView的顯示問題

2021-07-10 16:42:41 字數 1818 閱讀 6053

我們都知道在ios中,每乙個uiimageview都有他的frame大小,但是如果的大小和這個frame的大小不符合的時候會怎麼樣呢?在預設情況,會被壓縮或者拉伸以填滿整個區域。

通過檢視uiview的屬性可以知道,view的contentmode屬性可以用來控制的顯示情況。下面的設定可以讓進行居中顯示。

1imageview.contentmode =  uiviewcontentmodecenter;

這個居中是包括了,橫向和縱向都是居中。不會拉伸或者壓縮,就是按照imageview的frame和的大小來居中顯示的。

這裡有兩種情況:

1、比view的區域更大。這個時候會擷取的中間部位顯示在frame區域裡面。

2、比view的區域更小。這個時候會完整的顯示在frame的中間位置。

如果在預設情況,的多出來的部分還是會顯示螢幕上。如果不希望超過frame的區域顯示在螢幕上要設定。clipstobounds屬性。

1imageview.clipstobounds  = yes;

最後乙個問題,在iphone的retina螢幕上面,必須要設定,contentscalefactor屬性。這個屬性的預設值是1。二對應的retina螢幕需要是2.可以通過下面的方式來設定:

1[imageview setcontentscalefactor:[[uiscreen mainscreen] scale]];

但是用:

1imageview.contentmode =  uiviewcontentmodecenter;

也有他的問題,就是在不規則的時候,而且的寬或者高比frame的寬高更小的時候,會出現空白的情況。

為了解決這種問題可以設定:

1imageview.contentmode =  uiviewcontentmodescaleaspectfill;

這樣會拉伸或者壓縮以適應frame的邊界,而且是適應更小的邊,這樣可以達成的效果是,適應最小的邊鋪開顯示,更大的邊會超出frame,如果設定了clipstobounds屬性為yes,那麼更大的邊就會被截斷。這樣達成更好的居中顯示效果,完整的**如下:

1uiimage *pic = [ uiimage imagenamed:@"img_0404.png"];

2uiimageview *imageview   = [[uiimageview alloc] initwithframe:cgrectmake(20, 20, 240, 100 )];

3[imageview setimage:pic];

4[imageview setcontentscalefactor:[[uiscreen mainscreen] scale]];

5imageview.contentmode =  uiviewcontentmodescaleaspectfill;

6imageview.autoresizingmask = uiviewautoresizingflexibleheight;

7imageview.clipstobounds  = yes;

關於UIImageView的顯示問題

我們都知道在ios中,每乙個uiimageview都有他的frame大小,但是如果的大小和這個frame的大小不符合的時候會怎麼樣呢?在預設情況,會被壓縮或者拉伸以填滿整個區域。通過檢視uiview的屬性可以知道,view的contentmode屬性可以用來控制的顯示情況。下面的設定可以讓進行居中顯...

關於UIImageView的顯示問題

我們都知道在ios中,每乙個uiimageview都有他的frame大小,但是如果的大小和這個frame的大小不符合的時候會怎麼樣呢?在預設情況,會被壓縮或者拉伸以填滿整個區域。通過檢視uiview的屬性可以知道,view的contentmode屬性可以用來控制的顯示情況。下面的設定可以讓進行居中顯...

UIImageView的約束問題

在控制器的 viewdidload方法中呼叫如下方法 布局使用masonry框架 專案中有兩張 sqi test.png sqi test.jpg,都為400 400畫素 nsstring imgpath nsbundle mainbundle pathforresource sqi test.pn...