Android移動(dòng)應(yīng)用開發(fā)案例教程(模塊二 視頻播放項(xiàng)目UI設(shè)計(jì))_第1頁
Android移動(dòng)應(yīng)用開發(fā)案例教程(模塊二 視頻播放項(xiàng)目UI設(shè)計(jì))_第2頁
Android移動(dòng)應(yīng)用開發(fā)案例教程(模塊二 視頻播放項(xiàng)目UI設(shè)計(jì))_第3頁
Android移動(dòng)應(yīng)用開發(fā)案例教程(模塊二 視頻播放項(xiàng)目UI設(shè)計(jì))_第4頁
Android移動(dòng)應(yīng)用開發(fā)案例教程(模塊二 視頻播放項(xiàng)目UI設(shè)計(jì))_第5頁
已閱讀5頁,還剩36頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

Android移動(dòng)應(yīng)用開發(fā)案例教程模塊二視頻播放項(xiàng)目UI設(shè)計(jì)任務(wù)1SplashUI設(shè)計(jì)任務(wù)2主界面頂部標(biāo)題欄設(shè)計(jì)任務(wù)3主界面設(shè)計(jì)任務(wù)4底部菜單欄設(shè)計(jì)任務(wù)5視頻列表設(shè)計(jì)任務(wù)6播放器控制面板設(shè)計(jì)任務(wù)7視頻播放界面設(shè)計(jì)任務(wù)8引導(dǎo)界面設(shè)計(jì)

任務(wù)1SplashUI設(shè)計(jì)1AndroidManifest.xml的配置AndroidManifest.xml是應(yīng)用清單,每個(gè)應(yīng)用的根目錄中都必須包含一個(gè),并且文件名必須一模一樣。這個(gè)文件中包含了APP的配置信息,系統(tǒng)需要根據(jù)里面的內(nèi)容運(yùn)行APP的代碼,顯示界面。任務(wù)1SplashUI設(shè)計(jì)2Android布局Android中常用的布局有6種:LinearLayout(線性布局)、RelativeLayout(相對(duì)布局)、TableLayout(表格布局)、GridLayout(網(wǎng)絡(luò)布局)、FrameLayout(幀布局)、ConstraintLayout(約束布局),這些布局各自有自己的布局特點(diǎn),在布局中要綜合利用這些布局。屬性名稱屬性值描述id@+id/***設(shè)置唯一標(biāo)識(shí)background顏色、圖片或選擇器設(shè)置背景heightwrap_content/match_parent/自定義設(shè)置高度widthwrap_content/match_parent/自定義設(shè)置寬度gravitytop/bottom/left容器中子組件的對(duì)齊方式layout_gravitytop/bottom/left組件在父組件中的對(duì)齊方式padding***數(shù)值內(nèi)邊距margin***數(shù)值外邊距任務(wù)1SplashUI設(shè)計(jì)2Android布局

(1)線性布局Linearlayout線性布局LinearLayout是Android系統(tǒng)中最基礎(chǔ)一種布局。采用自上而下或者從左往右的方式將一個(gè)元素接著一個(gè)元素排列,當(dāng)排列的元素超出屏幕范圍時(shí),超出的部分將做隱藏處理。屬性名稱屬性值描述orientationhorizontal(水平排列)vertical(垂直排列)設(shè)置組件排列方式weight數(shù)值按權(quán)重分割父布局任務(wù)1SplashUI設(shè)計(jì)2Android布局

(2)相對(duì)布局RelativeLayout相對(duì)布局RelativeLayout是位置相對(duì)于兄弟組件或者布局容器的一種布局管理器。它繼承于android.widget.ViewGroup,其按照子元素之間的位置關(guān)系完成布局,作為Android系統(tǒng)布局中最靈活也是最常用的一種布局方式,非常適合于一些比較復(fù)雜的界面設(shè)計(jì)。任務(wù)1SplashUI設(shè)計(jì)2Android布局

(2)相對(duì)布局RelativeLayout相對(duì)于父容器的屬性:屬性名稱屬性值描述alignParentLefttrue/false將控件的左邊緣和父控件的左邊緣對(duì)齊alignParentToptrue/false將控件的上邊緣和父控件的上邊緣對(duì)齊alignParentRighttrue/false將控件的右邊緣和父控件的右邊緣對(duì)齊alignParentBottomtrue/false將控件的底邊緣和父控件的底邊緣對(duì)齊centerInParenttrue/false將控件置于父控件的中心位置centerHorizontaltrue/false將控件置于水平方向的中心位置centerVerticaltrue/false將控件置于垂直方向的中心位置任務(wù)1SplashUI設(shè)計(jì)2Android布局

(2)相對(duì)布局RelativeLayout相對(duì)于兄弟組件的屬性:屬性名稱屬性值描述layout_above@id/xxx將控件置于給定ID控件之上layout_below@id/xxx將控件置于給定ID控件之下layout_toLeftOf@id/xxx將控件置于給定ID控件左側(cè)layout_toRightOf@id/xxx將控件置于給定ID控件右側(cè)layout_alignLeft@id/xxx將控件的左邊緣和給定ID控件的左邊緣對(duì)齊layout_alignTop@id/xxx將控件的上邊緣和給定ID控件的上邊緣對(duì)齊layout_alignRight@id/xxx將控件的右邊緣和給定ID控件的右邊緣對(duì)齊layout_alignBottom@id/xxx將控件的底邊緣和給定ID控件的底邊緣對(duì)齊任務(wù)1SplashUI設(shè)計(jì)2Android布局

(3)網(wǎng)格布局GridLayout該布局使用虛線將布局劃分為行、列和單元格,也支持一個(gè)控件在行、列上都有交錯(cuò)排列。網(wǎng)絡(luò)布局更接近于人們所理解的表格。對(duì)于一個(gè)網(wǎng)格布局來說,需要明確劃分成幾行幾列。GridLayout網(wǎng)格布局常用的屬性:屬性名稱屬性值描述orientationhorizontal/vertical子元素的布局方向columnCount數(shù)值最大列數(shù)rowCount數(shù)值最大行數(shù)任務(wù)1SplashUI設(shè)計(jì)2Android布局

(3)

GridLayout網(wǎng)格布局中子元素常用的屬性:屬性名稱屬性值描述layout_column數(shù)值顯示該子控件的列l(wèi)ayout_row數(shù)值顯示該子控件的行l(wèi)ayout_columnSpan數(shù)值該控件所占的列數(shù)rowCount數(shù)值最大行數(shù)任務(wù)1SplashUI設(shè)計(jì)2Android布局

(4)幀布局FrameLayout所有添加到這個(gè)布局中的視圖都以層疊的方式顯示。第一個(gè)添加的組件放到最底層,最后添加到布局中的視圖顯示在最上面。上一層的會(huì)覆蓋下一層的控件。幀布局沒有什么特有屬性,在使用時(shí)可以通過設(shè)置組件的margin、layout_gravity來控制組件的位置。任務(wù)1SplashUI設(shè)計(jì)2Android布局

(5)表格布局TableLayoutTableLayout繼承了LinearLayout,因此它的本質(zhì)依然是線性布局管理器。每次向TableLayout中添加一個(gè)TableRow,該TableRow就是一個(gè)表格行。TableRow也是容器,因此它也可以不斷地添加其他組件,每添加一個(gè)子組件該表格就增加一列。如果直接向TableLayout中添加組件,那么這個(gè)組件將直接占用一行。屬性名稱屬性值描述Shrinkable數(shù)值,列數(shù)從0開始如果某個(gè)列被設(shè)為Shrinkable,那么該列的所有單元格的寬度可以被收縮,以保證該表格能適應(yīng)父容器的寬度Stretchable數(shù)值,列數(shù)從0開始如果某個(gè)列被設(shè)為Stretchable,那么該列的所有單元格的寬度可以被拉伸,以保證組件能完全填滿表格空余空間Collapsed數(shù)值,列數(shù)從0開始如果某個(gè)列被設(shè)為Collapsed,那么該列的所有單元格會(huì)被隱藏任務(wù)1SplashUI設(shè)計(jì)2Android布局

(6)約束布局ConstraintLayout項(xiàng)目中的布局嵌套問題對(duì)我們的項(xiàng)目性能有著不小的影響。布局能實(shí)現(xiàn)扁平化會(huì)讓軟件性能得到很大的提升。此它同時(shí)具有RelativeLayout和LinearLayout的優(yōu)點(diǎn)、特性,功能強(qiáng)大。約束布局從相對(duì)定位、居中定位、偏向、尺寸約束、比例、鏈條、環(huán)形定位等方面約束組件的位置。任務(wù)1SplashUI設(shè)計(jì)2Android布局

(6)約束布局ConstraintLayout居中定位屬性:居中方向?qū)傩灾邓絘pp:layout_constraintLeft_toLeftOf="parent"app:layout_constraintRight_toRightOf="parent"垂直app:layout_constraintTop_toTopOf="parent"app:layout_constraintBottom_toBottomOf="parent"水平垂直都居中水平+垂直任務(wù)1SplashUI設(shè)計(jì)2Android布局

(6)約束布局ConstraintLayout偏向?qū)傩裕簩傩悦Q描述layout_constraintHorizontal_bias水平(0最左邊1最右邊,默認(rèn)是0.5)layout_constraintVertical_bias垂直(0最上邊1最底邊,默認(rèn)是0.5)任務(wù)1SplashUI設(shè)計(jì)2Android布局

(6)約束布局ConstraintLayout相對(duì)定位屬性:屬性名稱屬性值描述layout_constraint***_to***Of

@id/***或者parentlayout_constraint***里的***代表是這個(gè)子控件自身的哪條邊(Left、Right、Top、Bottom、Baseline),而to***Of里的***代表的是和約束控件的哪條邊發(fā)生對(duì)齊(Left、Right、Top、Bottom、Baseline)任務(wù)1SplashUI設(shè)計(jì)2Android布局

(6)約束布局ConstraintLayout比例屬性:舉例:只有一個(gè)方向約束必須有至少一個(gè)相對(duì)定位(id/parent)layout_constraintXxx_toXxxOf,需要將至少一個(gè)約束維度設(shè)置為0dp。app:layout_constraintDimensionRatio="2:1"(寬:高=2:1)舉例:指定要改變的維度如果兩個(gè)維度均設(shè)置為0dp,也可以使用比例,屬性layout_constraintDimensionRatio="H,2:1"則表示動(dòng)態(tài)改變高度,高度調(diào)整為控件寬度的二分之—,比例始終都是

寬:高。屬性名稱描述app:layout_constraintDimensionRatio約束比例,用逗號(hào)分隔方向(,),用冒號(hào)(:)分隔比例任務(wù)1SplashUI設(shè)計(jì)3基礎(chǔ)控件

(1)TextView標(biāo)簽

TextView是一種顯示文本信息的控件,該控件直接繼承于View,從功能上看,類似于網(wǎng)頁中的標(biāo)簽Label控件。屬性名稱描述android:id這是唯一地標(biāo)識(shí)控件的IDandroid:gravity設(shè)置文本位置,如設(shè)置成“center”,文本將居中顯示android:drawable***在text的左/右/上/下面位置顯示一個(gè)drawable,如圖片android:textStyle設(shè)置字形bold(粗體)、italic(斜體)、粗+斜(bold|italic)android:text要顯示的文字android:textColor文本顏色??梢允且粋€(gè)顏色值,如形式“#rgb”,

“#argb”,“#rrggbb”,和“#aarrggbb”android:textSize文字的大小。文字推薦尺寸類型是“sp”的比例像素(例如:15sp)。android:background背景圖片android:singleLine單行顯示任務(wù)1SplashUI設(shè)計(jì)3基礎(chǔ)控件

(2)ImageView

ImageView用來顯示Drawable對(duì)象資源的控件,繼承于View控件。屬性名稱描述android:src設(shè)置控件的Drawable資源android:scaleType設(shè)置圖片的縮放或移動(dòng)的方式以適應(yīng)控件的大小android:maxWidth設(shè)置控件的最大寬度界面的實(shí)現(xiàn)android:adjustViewBounds設(shè)置是否保持寬高比。需要與maxWidth、MaxHeight一起使用,否則單獨(dú)使用沒有效果android:cropToPadding如果屬性設(shè)為true,該組件將會(huì)被裁剪到保留該ImageView的paddingandroid:maxHeight設(shè)置控件的最大高度,單獨(dú)使用無效,需要與setAdjustViewBounds一起使用。如果要設(shè)置圖片固定大小,又要保持圖片寬高比,則需要進(jìn)行如下設(shè)置:(1)設(shè)置setAdjustViewBounds為true;(2)設(shè)置maxWidth、maxHeight;(3)設(shè)置layout_width和layout_height為wrap_content任務(wù)1SplashUI設(shè)計(jì)4Activity

Activity是Android的是四大組件之一,也是使用最為頻繁的組件。生活中如打電話、發(fā)信息,用戶需要與手機(jī)進(jìn)行交互,在Android系統(tǒng)中就是通過Activity來實(shí)現(xiàn)的。在Android應(yīng)用程序中一般會(huì)有多個(gè)Activity,每一個(gè)Activity負(fù)責(zé)一個(gè)用戶界面的展現(xiàn)。通常一個(gè)用戶界面有一些基本組件(如按鈕、文本、列表等),并對(duì)這些基本組件編寫相應(yīng)的實(shí)現(xiàn)代碼(完成事件處理)。任務(wù)1SplashUI設(shè)計(jì)5Handler

Android為我們提供了一個(gè)消息機(jī)制即Handler。Handler寫在主線程中,創(chuàng)建一個(gè)handler并實(shí)現(xiàn)handleMessage方法。方法名字方法功能handleMessage(Messagemsg)處理消息的方法,通常是用于被重寫sendEmptyMessage(intwhat)發(fā)送空消息sendEmptyMessageDelayed(intwhat,longdelayMillis)指定延時(shí)多少毫秒后發(fā)送空信息sendMessage(Messagemsg)立即發(fā)送信息sendMessageDelayed(Messagemsg)指定延時(shí)多少毫秒后發(fā)送信息任務(wù)1SplashUI設(shè)計(jì)6省略標(biāo)題欄

Android中如果我們不需要標(biāo)題欄,那么我們可以將其去除,去除的方法大體可以分為兩種:代碼中實(shí)現(xiàn)和AndroidManifest.xml配置文件中實(shí)現(xiàn)。(1)代碼實(shí)現(xiàn)setContentView(R.layout.main)之前加入:requestWindowFeature(Window.FEATURE_NO_TITLE);if(getSupportActionBar()!=null)

{

getSupportActionBar().hide();

}

(2)配置文件中實(shí)現(xiàn)<application>標(biāo)簽注冊(cè)中修改Activity的主題樣式。android:theme="@style/Theme.AppCompat.NoActionBar"

(3)全屏的實(shí)現(xiàn)Activity中onCreate()方法的setContentView()代碼下面加入如下的語句。ViewdecorView=getWindow().getDecorView();decorView.setSystemUiVisibility(View.SYSTEM_UI_FLAG_FULLSCREEN);任務(wù)1SplashUI設(shè)計(jì)7事件處理事件處理包含三要素:事件源、發(fā)生了什么事件、事件處理者。事件處理步驟:(1)找到事件源

(2)為事件源注冊(cè)監(jiān)聽器:事件源.add***Listener()(3)編寫事件處理者事件處理者的編寫常用有三種方法:(1)匿名對(duì)象(2)使用本類(3)內(nèi)部類任務(wù)2主界面頂部標(biāo)題欄設(shè)計(jì)任務(wù)2主界面頂部標(biāo)題欄設(shè)計(jì)1ViewFlipperAndroid自帶的一個(gè)多頁面管理控件ViewFlipper,它可以自動(dòng)播放實(shí)現(xiàn)圖片翻轉(zhuǎn)功能。為ViewFlipper控件加入View有兩種方法。靜態(tài)導(dǎo)入:所謂的靜態(tài)導(dǎo)入就是像上面布局參考代碼加粗顯示的代碼行,用<include>將每個(gè)頁面添加到ViewFlipper的中間。動(dòng)態(tài)導(dǎo)入:在Java程序中通過addView方法填充View,方法名字方法功能setInAnimation設(shè)置View進(jìn)入屏幕時(shí)使用的動(dòng)畫setOutAnimation設(shè)置View退出屏幕時(shí)使用的動(dòng)畫showNext調(diào)用該方法來顯示ViewFlipper里的下一個(gè)ViewshowPrevious調(diào)用該方法來顯示ViewFlipper的上一個(gè)ViewsetFilpInterval設(shè)置View之間切換的時(shí)間間隔setAutoStart設(shè)置ViewFlipper自動(dòng)翻轉(zhuǎn)stopFlipping停止View切換任務(wù)2主界面頂部標(biāo)題欄設(shè)計(jì)2手勢(shì)識(shí)別一般情況下,我們知道View類有個(gè)View.OnTouchListener內(nèi)部接口,通過重寫它的onTouch(Viewv,MotionEventevent)方法,我們可以處理一些touch事件,但是這個(gè)方法太過簡(jiǎn)單,如果需要處理一些復(fù)雜的手勢(shì),用這個(gè)接口就會(huì)很麻煩。Android

SDK給我們提供了GestureDetector(Gesture:手勢(shì)Detector:識(shí)別)類,通過這個(gè)類我們可以識(shí)別很多的手勢(shì)。GestureDetector這個(gè)類對(duì)外提供了兩個(gè)接口和一個(gè)內(nèi)部類:接口:OnGestureListener,OnDoubleTapListener內(nèi)部類:SimpleOnGestureListener任務(wù)3主界面設(shè)計(jì)任務(wù)4底部菜單欄設(shè)計(jì)任務(wù)4底部菜單欄設(shè)計(jì)1CircularReveal動(dòng)畫特效這里的動(dòng)畫需要使用ViewAnimationUtils庫來實(shí)現(xiàn),但是該庫是5.0以后才引入的,所以無法滿足低版本。使用開源庫CircularReveal,主要是提供了波浪式的展開和回縮動(dòng)畫,利用這個(gè)庫提供的動(dòng)畫再自定義一下就很容易實(shí)現(xiàn)動(dòng)畫的效果了。createCircularReveal中參數(shù)的解釋如下:staticAnimatorcreateCircularReveal(Viewview,intcenterX,intcenterY,floatstartRadius,floatendRadius)view:就是需要執(zhí)行動(dòng)畫的對(duì)象,此處為底部菜單的圖片。centerX:動(dòng)畫中心點(diǎn)X坐標(biāo)centerY:動(dòng)畫中心點(diǎn)Y坐標(biāo)startRadius:動(dòng)畫開始時(shí)的圓半徑endRadius:動(dòng)畫結(jié)束時(shí)的圓半徑最后設(shè)置動(dòng)畫時(shí)長(zhǎng)和延遲,就可以執(zhí)行動(dòng)畫了。任務(wù)4底部菜單欄設(shè)計(jì)2FragmentFragment是Android3.0后引入的一個(gè)新的API,他出現(xiàn)的初衷是為了適應(yīng)大屏幕的平板電腦,當(dāng)然現(xiàn)在它仍然是平板APPUI設(shè)計(jì)的寵兒,而且我們普通手機(jī)開發(fā)也會(huì)加入這個(gè)Fragment,我們可以把他看成一個(gè)小型的Activity,又稱Activity片段。Fragment并不能單獨(dú)使用,他需要嵌套在Activity中使用,盡管它擁有自己的生命周期,但是還是會(huì)受到宿主Activity的生命周期的影響,比如Activity被destroy銷毀了,它也會(huì)跟著銷毀。任務(wù)4底部菜單欄設(shè)計(jì)2Fragment

Activity包含A和B兩個(gè)FragmentABA中選擇一項(xiàng)新聞后在B中顯示新聞內(nèi)容A中選擇一項(xiàng)新聞后打開BActivityActivityA包含AFragmentActivityB包含BFragment平板手機(jī)任務(wù)5主界面視頻列表界面設(shè)計(jì)任務(wù)5主界面視頻列表界面設(shè)計(jì)1控件的顯示與隱藏當(dāng)界面上的某個(gè)控件在界面加載之初需要隱藏時(shí),可以在所在布局的XML文件中修改android:visibility屬性,屬性值有三種。visibility屬性值含義gone隱藏、所占位置也不可見visible可見,默認(rèn)狀態(tài)invisible不可見,但所占位置保留,顯示一個(gè)透明的空間任務(wù)5主界面視頻列表界面設(shè)計(jì)2RecyclerViewRecyclerView是support-v7包中的新組件,是一個(gè)強(qiáng)大的滑動(dòng)組件,與經(jīng)典的ListView相比,同樣擁有item回收復(fù)用的功能,這一點(diǎn)從它的名字RecyclerView即回收view也可以看出。官方對(duì)于它的介紹則是:RecyclerView是ListView的升級(jí)版本,更加先進(jìn)和靈活??梢詫?shí)現(xiàn)水平、垂直、網(wǎng)絡(luò)、瀑布流等布局,還可以實(shí)現(xiàn)分組、頂部標(biāo)題懸浮、拖動(dòng)和滑動(dòng)刪除等功能。瀑布流布局任務(wù)6控制面板設(shè)計(jì)任務(wù)6控制面板設(shè)計(jì)1SeekBar進(jìn)度條,可以實(shí)現(xiàn)視頻播放進(jìn)度和聲音的調(diào)節(jié)。方法名字方法功能android:max滑動(dòng)條的最大值android:progress滑動(dòng)條的當(dāng)前值android:secondaryProgress二級(jí)滑動(dòng)條的進(jìn)度android:thumb滑塊的drawable任務(wù)6控制面板設(shè)計(jì)2編寫選擇器

在Android開發(fā)過程中,經(jīng)常對(duì)某一個(gè)View的背景在不同的狀態(tài)下,設(shè)置不同的背景,增強(qiáng)用戶體驗(yàn)。如果按鈕,在按下時(shí),背景變化,如果在代碼中動(dòng)態(tài)設(shè)置,相對(duì)比較麻煩。Android為我們提供了selector背景選擇器可以非常方便的解決這一問題

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論