Android零基礎入門第22節:ImageView的屬性和方法大全

來源:互聯網
上載者:User

標籤:適應   應用   完成   縮放   dad   布局檔案   xml檔案   a20   java   

通過前面幾期的學習,TextView控制項及其子控制項基本學習完成,可以在Android螢幕上顯示一些文字或者按鈕,那麼從本期開始來學習如何在進行圖片展示,這就是涉及到另外一個非常重要的控制項家族,那就是ImageView。

 

一、認識ImageView

ImageView繼承自View組件,主要功能是用於顯示圖片,可以顯示任意映像。ImageView與其子類的類圖如所示。

從可以看到,ImageView 還派生出了 ImageButton、ZoomButton等組件,因此ImageView支援的XML屬性、方法,基本上也可應用於ImageButton、 ZoomButton 等組件。ImageView 還QuickContactBadge,顯示關聯到特定連絡人的圖片。

下表顯示了ImageView支援的XML屬性及相關方法。

ImageView有兩個可以設定圖片的屬性,分別是:android:src和android:background,其中background通常指的是背景,而src指的是內容。另外當使用src填入圖片時,是按照圖片大小直接填充,並不會進行展開,而使用background填入圖片,則是會根據ImageView給定的寬度來進行展開。

ImageView所支援的android:scaleType屬性可指定如下屬性值。

 

  • matrix ( ImageView.ScaleType.MATRIX):使用 matrix 方式進行縮放。
  • fitXY ( lmageView.ScaleType.FIT_XY):對圖片橫向、縱向獨立縮放,使得該圖片完全適應於該ImageView,圖片的縱橫比可能會改變。
  • fitStart (ImageView.ScaleType.FIT_START ):保持縱橫比縮放圖片,直到該圖片能完全顯示在ImageView中(圖片較長的邊長與ImageView相應的邊長相等),縮放完成後將該圖片放在ImageView的左上方。
  • fitCenter (ImageView.ScaleType.FIT_CENTER ):保持縱橫比縮放圖片,直到該圖片能完全顯示在ImageView中(圖片較長的邊長與ImageView相應的邊長相等), 縮放完成後將該圖片放在ImageView的中央。
  • fitEnd (ImageView.ScaleType.FIT_END ):保持縱橫比縮放圖片,直到該圖片能完全顯示在ImageView中(圖片較長的邊長與ImageView相應的邊長相等),縮放完成後將該圖片放在ImageView的右下角。
  • center ( ImageView.ScaleType.CENTER):把圖片放在 ImageView 的中間,但不進行任何縮放。
  • centerCrop ( ImageView.ScaleType.CENTER_CROP):保持縱橫比縮放圖片,以使得圖片能完全覆蓋ImageView。只要圖片的最短邊能顯示出來即可。
  • centerlnside (ImageView.ScaleType.CENTER_INSIDE ):保持縱橫比縮放圖片,以使得ImageView能完全顯示該圖片。

 

為了控制ImageView顯示的圖片,ImageView提供了如下方法。

 

  • setlmageBitmap(Bitmap bm):使用 Bitmap 位元影像設定該 ImageView 顯示的圖片。
  • setlmageDrawable(Drawable drawable):使用 Drawable 對象設定該 ImageView 顯示的圖片。
  • setlmageResource(int resld):使用圖片資源ID設定該ImageView顯示的圖片。
  • setlmageURI(Uri uri):使用圖片的URI設定該ImageView顯示的圖片。

 

 

二、ImageView樣本

接下來通過一個簡單的樣本程式來學習ImageView的使用用法。

首先從網上下載一張圖片素材,然後放到res/drawable/目錄下,在到res/layout/目錄下建立一個image_layout.xml檔案,然後在其中填充如下程式碼片段:

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"              android:orientation="vertical"              android:layout_width="match_parent"              android:layout_height="match_parent">    <ImageView        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:src="@drawable/girl"/>    <ImageView        android:layout_width="80dp"        android:layout_height="80dp"        android:scaleType="fitXY"        android:src="@drawable/girl"/>    <ImageView        android:layout_width="100dp"        android:layout_height="100dp"        android:scaleType="center"        android:src="@drawable/girl"/></LinearLayout>

上面的介面布局檔案中定義了三個ImageView,其中第一個ImageView為預設屬性和自動寬高,第二個ImageView指定了 android:scaleType=fitXY,第三個ImageView指定了 android:scaleType=center。

然後修改一下app/src/java/MainActivity.java檔案中載入的布局檔案為建立的image_layout.xml檔案。運行程式,可以看到所示介面效果。

 到此,ImageView的樣本結束,關於ImageView的更多用法可以參照上面的XML屬性和方法參照表,建議多動手練習。

-----------------------------------------------

今天就先到這裡,下一期開始UI組件的學習。如果有問題歡迎留言一起探討,也歡迎加入Android零基礎入門技術討論群,共同成長!

往期總結分享:

Android零基礎入門第1節:Android的前世今生

Android零基礎入門第2節:Android 系統架構和應用組件那些事

Android零基礎入門第3節:帶你一起來聊一聊Android開發環境

Android零基礎入門第4節:正確安裝和配置JDK, 高富帥養成第一招

Android零基礎入門第5節:善用ADT Bundle, 輕鬆邂逅女神

Android零基礎入門第6節:配置最佳化SDK Manager, 正式約會女神

Android零基礎入門第7節:搞定Android模擬器,開啟甜蜜之旅

Android零基礎入門第8節:HelloWorld,我的第一趟旅程出發點

Android零基礎入門第9節:Android應用實戰,不懂代碼也可以開發

Android零基礎入門第10節:開發IDE大升級,終於迎來了Android Studio

Android零基礎入門第11節:簡單幾步帶你飛,運行Android Studio工程

Android零基礎入門第12節:熟悉Android Studio介面,開始裝逼賣萌

Android零基礎入門第13節:Android Studio配置最佳化,打造開發利器

Android零基礎入門第14節:使用高速Genymotion,跨入火箭時代

Android零基礎入門第15節:掌握Android Studio項目結構,揚帆起航

Android零基礎入門第16節:Android使用者介面開發概述

Android零基礎入門第17節:TextView屬性和方法大全

Android零基礎入門第18節:EditText的屬性和使用方法

Android零基礎入門第19節:Button使用詳解

Android零基礎入門第20節:CheckBox和RadioButton使用大全

Android零基礎入門第21節:ToggleButton和Switch使用大全

此文章著作權為公眾號分享達人秀(ShareExpert)——鑫鱻所有,若轉載請備忘出處,特此聲明!

Android零基礎入門第22節:ImageView的屬性和方法大全

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.