androidview參數
『壹』 android如何實現textview水平垂直居中
1、方法:設置textview的屬性android:layout_gravity="center"
2、補充:
(1)android:layout_gravity:View組件相對於Container的對齊方式。center表示將對象橫縱居中,不改變其大小。
(2)屬性可選的值還有:top、bottom、left、right、center_vertical、fill_vertical、center_horizontal、fill_horizontal、fill、clip_vertical。
3、android
(1)Android是一種基於Linux的自由及開放源代碼的操謹慧作系統,主要使用於祥粗答移動設備,如智能手機和平板電腦,由Google公司和開放手機聯盟領導及開發。尚未有統一中文名稱,中國大陸地區較多人使用「安卓」或「安致」。Android操凳猜作系統最初由Andy Rubin開發,主要支持手機。2005年8月由Google收購注資。
(2)2007年11月,Google與84家硬體製造商、軟體開發商及電信營運商組建開放手機聯盟共同研發改良Android系統。隨後Google以Apache開源許可證的授權方式,發布了Android的源代碼。第一部Android智能手機發布於2008年10月。Android逐漸擴展到平板電腦及其他領域上,如電視、數碼相機、游戲機等。2011年第一季度,Android在全球的市場份額首次超過塞班系統,躍居全球第一。
4、textview:textView是用來顯示字元串的組件,在手機上就是顯示一塊文本的區域。
『貳』 Android 的void android.view.Window.setFlags(int flags, int mask) 的兩個參數有啥意義
應該設置的值
應該被改變的設置值的位
這樣如果setVisiability設置了其他值比如4564654是沒效果的
使用這些位操作可以確定以前是是什麼狀態將要變成什麼狀態,便於控制進行正確的操作
例如從gone到invisible需要重新布局,從visiable到invisible就不需要布局只需要重繪
例如:Visiablity系統中:
如publicstaticfinalintGONE=0x00000008;
publicstaticfinalintVISIBLE=0x00000000;
VISIBILITY_MASK控制的標志位
不同的mask代表不用的功能,他們的位也是不同的
staticfinalintVISIBILITY_MASK=0x0000000C;=00000001100
拿View中setVisiability(Gone)為例假設舊的值是Visiable=0x00000000
@RemotableViewMethod
publicvoidsetVisibility(intvisibility){
setFlags(visibility,VISIBILITY_MASK);
if(mBGDrawable!=null)mBGDrawable.setVisible(visibility==VISIBLE,false);
}
old保存mViewFlags之前的值,
old和mViewFlags異或後得到一個新的changed凡是為1說明發送了變化,就需要View系統進行調整了!
在setFlag函數中
flags=0x0000000100
intold=mViewFlags;//舊的flag=0x00000000
mViewFlags=(mViewFlags&~mask)|(flags&mask);//新的flag
0x00000000&~(00000001100)|&00000001100=0x0000000100
intchanged=mViewFlags^old;=0x0000000100
if(changed==0){
return;//hey!沒有變化!直接return!
}
flags&VISIBILITY_MASK=1
if((flags&VISIBILITY_MASK)==VISIBLE){//不執行顯示操作
if((changed&GONE)!=0){//changed&GONE=1
needGlobalAttributesUpdate(false);
requestLayout();//重新布局
if(((mViewFlags&VISIBILITY_MASK)==GONE)){//成立開始清除view的cache重繪
if(hasFocus())clearFocus();
destroyDrawingCache();
if(mParentinstanceofView){
//GONEviewsnoopinvalidation,soinvalidatetheparent
((View)mParent).invalidate(true);
}
//
//
mPrivateFlags|=DRAWN;
}
if(mAttachInfo!=null){
mAttachInfo.mViewVisibilityChanged=true;
}
}
『叄』 如何設置android webview默認為高等像素密度
因為Android下瀏覽器默認的並不是實際像素,而是中像素密度。(註:Android支持三種屏幕像素密度:低像素密度,中像素密度,高像素密度),所以要設置android webview默認為高等像素密度的話,需要在js中設置如下代碼:
<metacontent='width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no,target-densitydpi=device-dpi'name='viewport'>
這裡面,target-densitydpi的功能就是指定屏幕像素密度DPI。它的參數有:
device-dpi –使用設備原本的 dpi 作為目標dpi。不會發生默認縮放。
high-dpi – 使用hdpi作為目標dpi。中等像素密度和低像素密度設備相應縮小。
medium-dpi – 使用mdpi作為目標dpi。 高像素密度設備相應放大, 像素密度設備相應縮小。這是默認的target density。
low-dpi -使用mdpi作為目標dpi。中等像素密度和高像素密度設備相應放大。
<value> – 指定一個具體的dpi值作為target dpi。這個值的范圍必須在70–400之間。
『肆』 Android獲取View的寬和高(一)
在Android開發中,有時會遇到動態調整布局需求,如讓第三個按鈕位於前兩個按鈕的中間位置。在onCreate()或onResume()生命周期中,無法獲取到View的寬高、邊距等信息,因為這些操作在onResume()之後執行。為了解決這一問題,可以利用ViewTreeObserver,它能監聽視圖樹的全局變化,提供View的寬高和margin信息。
ViewTreeObserver是一個注冊監聽視圖樹的觀察者,會監聽視圖樹發生全局變化時發出的通知,包括布局、繪畫過程、觸摸模式改變等。由於ViewTreeObserver無法由應用程序實例化,而是由視圖提供,它主要提供了幾個內部類,如OnGlobalLayoutListener、OnPreDrawListener、OnDrawListener等。
通過這些監聽器,可以在特定時機獲取View的寬高和margin值。例如,要讓第三個按鈕位於前兩個按鈕中間,可以在Button02的LayoutParams中設置相應的屬性。具體實現步驟如下:
1. 創建一個Button02實例。
2. 通過Button02實例獲取到其View對象。
3. 為View對象注冊OnGlobalLayoutListener或OnPreDrawListener監聽器。
4. 在監聽器的回調方法中,使用View對象的getMeasuredWidth()和getMeasuredHeight()方法獲取寬高信息,使用getPaddingLeft()、getPaddingTop()、getPaddingRight()、getPaddingBottom()獲取邊距信息。
5. 根據獲取到的信息調整Button02的布局參數,使其居中於前兩個按鈕之間。
需要注意的是,這些監聽器可能會多次觸發,因此在獲取到View的寬高後,需要調用remove()方法移除相應的監聽器,避免重復操作。
通過上述步驟,可以靈活地動態調整布局,實現按鈕間的精確對齊,提升應用的用戶體驗。
『伍』 Android 自定義View:為什麼你設置的wrap_content不起作用
在使用自定義View時,View寬 / 高的 wrap_content 屬性不起自身應有的作用,而且是起到與 match_parent 相同作用。
其實這里有兩個問題:
請分析 & 解決問題之前,請先看自定義View原理中 (2)自定義View Measure過程 - 最易懂的自定義View原理系列
問題出現在View的寬 / 高設置,那我們直接來看自定義View繪制中第一步對View寬 / 高設置的過程:measure過程中的 onMeasure() 方法
繼續往下看 getDefaultSize()
從上面發現:
那麼有人會問:wrap_content和match_parent具有相同的效果,為什麼是填充父容器的效果呢?
我們知道,子View的MeasureSpec值是根據子View的布局參數(LayoutParams)和父容器的MeasureSpec值計算得來,具體計算邏輯封裝在getChildMeasureSpec()里。
接下來,我們看生成子View MeasureSpec的方法: getChildMeasureSpec() 的源碼分析:
getChildMeasureSpec()
從上面可以看出,當子View的布局參數使用 match_parent 或 wrap_content 時:
所以: wrap_content 起到了和 match_parent 相同的作用:等於父容器當前剩餘空間大小
當自定義View的布局參數設置成wrap_content時時,指定一個默認大小(寬 / 高)。
這樣,當你的自定義View的寬 / 高設置成wrap_content屬性時就會生效了。
網上流傳著這么一個解決方案:
答: 是,當父View為 AT_MOST 、View為 match_parent 時,該View的 match_parent 的效果就等於 wrap_content 。上述方法存在邏輯錯誤,但由於這種情況非常特殊的,所以導致最終的結果沒有錯誤。具體分析請看下面例子:
從上面的效果可以看出,View大小 = 默認值
我再將子View的屬性改為 wrap_content :
從上面的效果可以看出,View大小還是等於默認值。
相信看到這里你已經看懂了:
為了更好的表示判斷邏輯,我建議你們用本文提供的解決方案,即根據布局參數判斷默認值的設置
不定期分享關於 安卓開發 的干貨,追求 短、平、快 ,但 卻不缺深度 。
『陸』 Android基礎學習-View概述
在Android應用開發中,View是構建用戶界面的核心組件,它是所有控制項的基類,可以理解為UI界面中的矩形區域,比如TextView、Button、ImageView等基本控制項,以及能容納多個View的容器,如LinearLayout、RelativeLayout、ListView、RecyclerView等,它們共同構成了Android的視圖層次結構。
View的位置和大小通過四個頂點坐標決定,這些坐標對應於getLeft(), getRight(), getTop(), 和 getBottom() 方法,進而可以計算出寬度(right - left)和高度(bottom - top)。理解並設置好這些屬性,能精確控制控制項在屏幕上的布局。
View與用戶的交互主要通過MotionEvent事件來實現,當手指接觸屏幕時,會觸發ACTION_DOWN,手指移動則觸發ACTION_MOVE,手指離開屏幕則為ACTION_UP。通過設置onTouch事件,可以捕獲並響應這些動作,為用戶提供豐富的交互體驗。
在Android中,View的表示方式有兩種:一是通過XML布局文件,比如在一個垂直排列的LinearLayout中,你可以放置一個TextView和一個Button。二是通過Java代碼動態創建和管理,例如創建一個LinearLayout,設置其子控制項方向為垂直,然後添加文本框和按鈕實例。這兩種方法都可以達到相同的效果,開發者可以根據項目需求靈活選擇。
View是UI設計的基礎,無論是簡單的文本顯示還是復雜的交互界面,都離不開View的構建。後續的內容將深入探討更多View控制項及其自定義方法,敬請關注。