日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > > 充電吧
[導讀]1、 public class View extends Objectimplements Drawable.Callback KeyEvent.Callback AccessibilityEven

1、 public class View extends Object
implements Drawable.Callback KeyEvent.Callback AccessibilityEventSource java.lang.Object ???? android.view.View ? Class Overview

This class represents the basic building block for user interface components. A View occupies a rectangular area on the screen and is responsible for drawing and event handling. View is the base class forwidgets, which are used to create interactive UI components (buttons, text fields, etc.).

public abstract class ? View是Android中所有控件的基類,Button/TextView/RelativeLayout/ListView等,其共同基類都是View。View是界面層的控件的一種抽象,待變一個控件。 ViewGroup extends View
implements ViewManager ViewParent


java.lang.Object ???? android.view.View ? ???? android.view.ViewGroup ? Class Overview

A ViewGroup is a special view that can contain other views (called children.) The view group is the base class for layouts and views containers.

ViewGroup內(nèi)部包含一組View,ViewGroup也繼承自View,這就說明View本身就可以使單個控件或多個控件組成的一組控件。

UI界面架構圖:


每個Activity都包含一個Window對象,Window對象通常由PhoneWindow來實現(xiàn)。PhoneWindow將一個DecorWindow設置為整個窗口的根View。DecView里有所有View的監(jiān)聽事件,通過WindowManagerService進行接收,并通過Activity對象回調(diào)相應的onClickListener。顯示界面上,將屏幕分為兩部分,分別為TitleView和ContentView。ContentView是一個ID為content的FrameLayout,布局文件activity_main.xml就是設置在這樣一個FrameLayout中。

2、

View的位置參數(shù):

View根據(jù)上圖得到View的寬高和坐標(相對于ViewGroup,而不是原點)的關系:

width = right - left;

height = bottom - top;

獲取這幾個參數(shù)的方法如下:

mLeft?=?getLeft();
mRight?=?getRight();
mTop?=?getTop();
mBottom?=?getBottpm();

Android3.0開始View增加了幾個參數(shù):x,y,translationX,translationY,其中x,y是View左上角的坐標,translationX,translationY是View左上角相對于父容器的偏移量:

x = left + translationX;

y = top + translationY;

需要注意:View在平移過程中,top/left表示的是原始左上角的位置信息,其值在移動期間不會發(fā)生改變,變化的是x,y,translationX,translationY.


3、View的三大流程(measure,layout,draw)之View的測量

View的繪制流程從ViewRoot的performTraversals方法開始,ViewRoot對應于ViewRootImpl類,是連接WindowManager和DecorView的紐帶,View的三大流程均是通過ViewRoot來完成。在ActivityThread中,當Activity對象被創(chuàng)建完畢后,會將DecorView添加到Window中,同時會創(chuàng)建ViewRootImpl對象,并將ViewRootImpl對象與DecorView相關聯(lián):

root?=?new?ViewRootImpl(view.getContext(),display);
root.setView(view,wparams,panelParentView);

View的繪制流程從ViewRoot的performTraversals方法開始,經(jīng)過measure,layout,draw三個過程將一個View繪制出來。

performTraversals會依次調(diào)用performMeasure,performLayout,performDraw三個方法,分別完成頂級View的measure,layout,draw三大流程,其中performMeasure中會調(diào)用measure方法,在measure方法中又調(diào)用onMeasure方法,在inMeasure方法中會對所有子元素進行measure過程,此時measure流程就從父元素傳到子元素了,這樣完成了一次measure過程。接著子元素會重復父容器的measure過程,如此反復完成整個View樹的遍歷。performLayout與performDraw與之類似,不同的是performDraw的傳遞過程是在draw方法中通過dispatchDraw來實現(xiàn)。

測量過程在onMeasure()方法中進行。

Android提供了一個功能強大的類--MeasureSpec類。

public static class View.MeasureSpec extends Object
java.lang.Object ???? android.view.View.MeasureSpec Summary: Constants |Ctors | Methods | Inherited Methods | [Expand All] Added in API level 1


public static class View.MeasureSpec extends Object
java.lang.Object ???? android.view.View.MeasureSpec Class Overview

A MeasureSpec encapsulates the layout requirements passed from parent to child. Each MeasureSpec represents a requirement for either the width or the height. A MeasureSpec is comprised of a size and a mode. There are three possible modes:

UNSPECIFIED The parent has not imposed any constraint on the child. It can be whatever size it wants.EXACTLY The parent has determined an exact size for the child. The child is going to be given those bounds regardless of how big it wants to be.AT_MOST The child can be as large as it wants up to the specified size.


MeasureSpec是一個32位的int值,高2位為測量模式(SpecMode),低30位是測量大?。⊿pecSize).

View默認的onMeasure()方法只支持EXACTLY模式,因此如果讓自定義View支持wrap_content屬性,就必須重寫onMeasure()方法來指定wrap_content大小(進一步說明,由源碼得出,wrap_content下的SpecMode是AT_MOST,此時的specSize是parentSize,即如果不指定wrap_content,在布局中使用wrap_content就相當于使用match_parent).

解決方法:

protected?void?onMeasure(int?widthMeasureSpec,int?heightMeasureSpec){
	super.onMeasure(widthMeasureSpec,?heightMeasureSpec);
	int?widthSpecMode?=?MeasureSpec.getMode(widthMeasureSpec);
	int?widthSpecSize?=?MeasureSpec.getSize(widthMeasureSpec);
	int?heightSpecMode?=?MeasureSpec.getMode(heightMeasureSpec);
	int?heightSpecSize?=?MeasureSpec.getSize(heightMeasureSpec);
	
	if(widthSpecMode?==?MeasureSpec.AT_MOST?&&?heightSpecMode?==?MeasureSpec.AT_MOST){
		setMeasureDimension(mWidth,mHeight);
	}else?if(widthSpecMode?==?MeasureSpec.AT_MOST){
		setMeasureDimension(mWidth,heightSpecSize);
	}else?if(heightSpecMode?==?MeasureSpec.AT_MOST){
		setMeasureDimension(widthSoecSize,mHeight)
	}
}

在上面代碼中指定View的默認寬高(mWidth/mHeight),并在wrap_content時設置此寬高。
Demo:

MeasureView.java


?

package?sunny.example.ahthreeviewmeasure;

import?android.content.Context;
import?android.util.AttributeSet;
import?android.view.View;
import?android.widget.Button;
import?android.widget.TextView;

public?class?MeasureView?extends?View{

	public?MeasureView(Context?context)?{
		super(context);
		//?TODO?Auto-generated?constructor?stub
		?
	}
	
	public?MeasureView(Context?context,?AttributeSet?attrs)?{
		super(context,?attrs);
		//?TODO?Auto-generated?constructor?stub
	}
	
	public?MeasureView(Context?context,?AttributeSet?attrs,?int?defStyle)?{
		super(context,?attrs,?defStyle);
		//?TODO?Auto-generated?constructor?stub
	}

	@Override
	protected?void?onMeasure(int?widthMeasureSpec,int?heightMeasureSpec){
		super.onMeasure(widthMeasureSpec,?heightMeasureSpec);
		int?widthSpecMode?=?MeasureSpec.getMode(widthMeasureSpec);
		int?widthSpecSize?=?MeasureSpec.getSize(widthMeasureSpec);
		int?heightSpecMode?=?MeasureSpec.getMode(heightMeasureSpec);
		int?heightSpecSize?=?MeasureSpec.getSize(heightMeasureSpec);
		
		if(widthSpecMode?==?MeasureSpec.AT_MOST?&&?heightSpecMode?==?MeasureSpec.AT_MOST){
			setMeasuredDimension(400,400);//指定寬高
		}else?if(widthSpecMode?==?MeasureSpec.AT_MOST){
			setMeasuredDimension(400,heightSpecSize);
		}else?if(heightSpecMode?==?MeasureSpec.AT_MOST){
			setMeasuredDimension(widthSpecSize,400);
		}
	}

	

}

?

activity_main.xml



MainActivity.java

?

package?sunny.example.ahthreeviewmeasure;

import?android.support.v7.app.ActionBarActivity;
import?android.os.Bundle;

public?class?MainActivity?extends?ActionBarActivity?{

	@Override
	protected?void?onCreate(Bundle?savedInstanceState)?{
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		//MeasureView?mView?=?(MeasureView)findViewById(R.id.measureView);
	}

	
}

?

?

?

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅(qū)動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅(qū)動性能的關鍵。

關鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質(zhì)量和效率直接關系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅(qū)動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關鍵字: LED 驅(qū)動電源 開關電源

LED驅(qū)動電源是把電源供應轉換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅(qū)動電源
關閉