android view([Android] View 的继承关系)
本文目录
- [Android] View 的继承关系
- Android view和viewgroup的区别,越详细越好!!
- Android - View 绘制流程
- android中的View是做什么的
- oppo手机中的androidView是做什么的
- 谁知道android 中view 和Viewgroup的关系是什么
[Android] View 的继承关系
在 Android 所有的控件和 Layout 都有着一个父类 View 。Anroid 通过继承的方式,对父类控件进行继承,由此来在父类基础上创造新的控件。 我们先看看 View 这个父类 可以看到间接继承的有100多个子类,不得不说 View 这个爹很成功(Object 斜眼)。 我们先拿其中的 ViewGroup 来说吧 可以看到大部分的 Layout 都继承自 ViewGroup 。一个 ViewGroup 可以包含别的 View 或 ViewGroup 。所以一个视图的根布局,通常是一个 ViewGroup 。 对于其中的 LinearLayout , RelativeLayout , GridLayout 等 Layout 大家应该都比较熟悉了。 但是看看里面还有一些控件,这些控件同样有着包含别的 View 或 ViewGroup 的功能。比如 RecyclerView , AdapterView 。 可能你会问,这个 AdapterView 是什么玩意。其实这个是我们常用的 GridView, ListView 的父类,换句话说,GridView, ListView 也属于 ViewGroup ,他们都能包含其他的 View 或 ViewGroup。相信你在使用 ListView 的时候一定在里面添加了一些控件的吧。 不得不说 TextView 也是一个强大的父类,很多的控件都继承自它。 其中常见的有 Button,EditText,CheckBox,RadioButton 等,我们发现啊。。貌似只要带有文字的控件基本都来继承自 TextView。这是他作为父类的特点。 ImageView 带有显示图片的特性,然而很少有控件需要这个特性,所以相对来说子类就比较少了。 其中比较用的多的就是 ImageButton 了,现在 Android 还提供了原生的 FloatingActionButton 也是极好的。 以上提出来说的三个子类是在整个 View 体系中比较重要的,其中以 ViewGroup 最为繁杂,派生类最多,而且其中有控件,有布局。TextView 则以子类控件继承为主。ImageView 的话相对需求较少。 我们给出一个简略图,可以直观的看到整个体系中常用类的继承结构。 ps1:上图包括直接子类和派生之类 ps2:如果想查看完整的继承结构,请查看 官方文档
Android view和viewgroup的区别,越详细越好!!
简单的讲,view类是android中众多UI组件的父类;viewgroup也继承自view类,它是UI组件的容器;举例讲,view类的子类有TextView,EditView这种文本框;viewGroup类的子类有Linearlayout,Slidingmenu等布局。
Android - View 绘制流程
我们知道,在 Android 中,View 绘制主要包含 3 大流程:
Android 中,主要有两种视图: View 和 ViewGroup ,其中:
虽然 ViewGroup 继承于 View ,但是在 View 绘制三大流程中,某些流程需要区分 View 和 ViewGroup ,它们之间的操作并不完全相同,比如:
对 View 进行测量,主要包含两个步骤:
对于第一个步骤,即求取 View 的 MeasureSpec ,首先我们来看下 MeasureSpec 的源码定义:
MeasureSpec 是 View 的一个公有静态内部类,它是一个 32 位的 int 值,高 2 位表示 SpecMode(测量模式),低 30 位表示 SpecSize(测量尺寸/测量大小)。 MeasureSpec 将两个数据打包到一个 int 值上,可以减少对象内存分配,并且其提供了相应的工具方法可以很方便地让我们从一个 int 值中抽取出 View 的 SpecMode 和 SpecSize。
一个 MeasureSpec 表达的是:该 View 在该种测量模式(SpecMode)下对应的测量尺寸(SpecSize)。其中,SpecMode 有三种类型:
对 View 进行测量,最关键的一步就是计算得到 View 的 MeasureSpec ,子View 在创建时,可以指定不同的 LayoutParams (布局参数), LayoutParams 的源码主要内容如下所示:
其中:
LayoutParams 会受到父容器的 MeasureSpec 的影响,测量过程会依据两者之间的相互约束最终生成子View 的 MeasureSpec ,完成 View 的测量规格。
简而言之,View 的 MeasureSpec 受自身的 LayoutParams 和父容器的 MeasureSpec 共同决定( DecorView 的 MeasureSpec 是由自身的 LayoutParams 和屏幕尺寸共同决定,参考后文)。也因此,如果要求取子View 的 MeasureSpec ,那么首先就需要知道父容器的 MeasureSpec ,层层逆推而上,即最终就是需要知道顶层View(即 DecorView )的 MeasureSpec ,这样才能一层层传递下来,这整个过程需要结合 Activity 的启动过程进行分析。
我们知道,在 Android 中, Activity 是作为视图组件存在,主要就是在手机上显示视图界面,可以供用户操作, Activity 就是 Andorid 中与用户直接交互最多的系统组件。
Activity 的基本视图层次结构如下所示:
Activity 中,实际承载视图的组件是 Window (更具体来说为 PhoneWindow ),顶层View 是 DecorView ,它是一个 FrameLayout , DecorView 内部是一个 LinearLayout ,该 LinearLayout 由两部分组成(不同 Android 版本或主题稍有差异): TitleView 和 ContentView ,其中, TitleView 就是标题栏,也就是我们常说的 TitleBar 或 ActionBar , ContentView 就是内容栏,它也是一个 FrameLayout ,主要用于承载我们的自定义根布局,即当我们调用 setContentView(...) 时,其实就是把我们自定义的布局设置到该 ContentView 中。
当 Activity 启动完成后,最终就会渲染出上述层次结构的视图。
因此,如果我们要求取得到子View 的 MeasureSpec ,那么第一步就是求取得到顶层View(即 DecorView )的 MeasureSpec 。大致过程如下所示:
经过上述步骤求取得到 View 的 MeasureSpec 后,接下来就可以真正对 View 进行测量,求取 View 的最终测量宽/高:
Android 内部对视图进行测量的过程是由 View#measure(int, int) 方法负责的,但是对于 View 和 ViewGroup ,其具体测量过程有所差异。
因此,对于测量过程,我们分别对 View 和 ViewGroup 进行分析:
综上,无论是对 View 的测量还是 ViewGroup 的测量,都是由 View#measure(int widthMeasureSpec, int heightMeasureSpec) 方法负责,然后真正执行 View 测量的是 View 的 onMeasure(int widthMeasureSpec, int heightMeasureSpec) 方法。
具体来说, View 直接在 onMeasure(...) 中测量并设置自己的最终测量宽/高。在默认测量情况下, View 的测量宽/高由其父容器的 MeasureSpec 和自身的 LayoutParams 共同决定,当 View 自身的测量模式为 LayoutParams.UNSPECIFIED 时,其测量宽/高为 android:minWidth / android:minHeight 和其背景宽/高之间的较大值,其余情况皆为自身 MeasureSpec 指定的测量尺寸。
而对于 ViewGroup 来说,由于布局特性的丰富性,只能自己手动覆写 onMeasure(...) 方法,实现自定义测量过程,但是总的思想都是先测量 子View 大小,最终才能确定自己的测量大小。
当确定了 View 的测量大小后,接下来就可以来确定 View 的布局位置了,也即将 View 放置到屏幕具体哪个位置。
View 的布局过程由 View#layout(...) 负责,其源码如下:
View#layout(...) 主要就做了两件事:
ViewGroup 的布局流程由 ViewGroup#layout(...) 负责,其源码如下:
可以看到, ViewGroup#layout(...) 最终也是通过 View#layout(...) 完成自身的布局过程,一个注意的点是, ViewGroup#layout(...) 是一个 final 方法,因此子类无法覆写该方法,主要是 ViewGroup#layout(...) 方法内部对子视图动画效果进行了相关设置。
由于 ViewGroup#layout(...) 内部最终调用的还是 View#layout(...) ,因此, ViewGroup#onLayout(...) 就会得到回调,用于处理 子View 的布局放置,其源码如下:
由于不同的 ViewGroup ,其布局特性不同,因此 ViewGroup#onLayout(...) 是一个抽象方法,交由 ViewGroup 子类依据自己的布局特性,摆放其 子View 的位置。
当 View 的测量大小,布局位置都确定后,就可以最终将该 View 绘制到屏幕上了。
View 的绘制过程由 View#draw(...) 方法负责,其源码如下:
其实注释已经写的很清楚了, View#draw(...) 主要做了以下 6 件事:
我们知道,在 Activity 启动过程中,会调用到 ActivityThread.handleResumeActivity(...) ,该方法就是 View 视图绘制的起始之处:
可以看到, ActivityThread.handleResumeActivity(...) 主要就是获取到当前 Activity 绑定的 ViewManager ,最后调用 ViewManager.addView(...) 方法将 DecorView 设置到 PhoneWindow 上,也即设置到当前 Activity 上。 ViewManager 是一个接口, WindowManager 继承 ViewManager ,而 WindowManagerImpl 实现了接口 WindowManager ,此处的 ViewManager.addView(...) 实际上调用的是 WindowManagerImpl.addView(...) ,源码如下所示:
WindowManagerImpl.addView(...) 内部转发到 WindowManagerGlobal.addView(...) :
在 WindowManagerGlobal.addView(...) 内部,会创建一个 ViewRootImpl 实例,然后调用 ViewRootImpl.setView(...) 将 ViewRootImpl 与 DecorView 关联到一起:
ViewRootImpl.setView(...) 内部首先关联了传递过来的 DecorView (通过属性 mView 指向 DecorView 即可建立关联),然后最终调用 requestLayout() ,而 requestLayout() 内部又会调用方法 scheduleTraversals() :
ViewRootImpl.scheduleTraversals() 内部主要做了两件事:
Choreographer.postCallback(...) 会申请一次 VSYNC 中断信号,当 VSYNC 信号到达时,便会回调 Choreographer.doFrame(...) 方法,内部会触发已经添加的回调任务, Choreographer 的回调任务有以下四种类型:
因此, ViewRootImpl.scheduleTraversals(...) 内部通过 mChoreographer.postCallback(Choreographer.CALLBACK_TRAVERSAL, mTraversalRunnable, null) 发送的异步视图渲染消息就会得到回调,即回调 mTra
android中的View是做什么的
View类是Android的一个超类,这个类几乎包含了所有的屏幕类型。每一个View都有一个用于绘图的画布,这个画布可以进行任意扩展。在游戏开发中叶可以自定义视图(View),这个画布的功能更能满足我们在游戏开发中的需要。在Android中,任何一个View类都只需重写onDraw 方法来实现界面显示,自定义的视图可以是复杂的3D实现,也可以是非常简单的文本形式等。
游戏中最重要的就是需要与玩家交互,比如键盘输入、触笔点击事件,Android中提供了 onKeyUp、onKeyDown、onKeyMultiple、onTouchEvent、onTrackballEvent等方法,可以轻松地处理游戏中的事件信息。
invalidate不能直接在线程中调用,就是不可以在子线程中调用明白乎?因为它违背了Android的单线程模型:Android UI操作并不是线程安全的,并且这些操作必须在UI 线程中执行,因此Android中最常用的方法就是利用Handler来实现UI线程的更新。 其实用AsyncTask也可以。
oppo手机中的androidView是做什么的
oppo手机中的androidView中文是:安卓系统视图。AndroidActivityManager框架 Android-View 的刷新机制Android View 的刷新机制……。
谁知道android 中view 和Viewgroup的关系是什么
View对象是Android平台中用户界面体现的基础单位。View类通常为“widgets(工具)”的子类的基础,它们提供了诸如文本输入框和按钮之类的UI对象的完整实现。ViewGroup类同样为被称为“Layouts(布局)”的子类奠定了基础,它们提供了象流式布局、表格布局以及相对布局之类的布局架构。
Android的UI界面都是由View和ViewGroup及其派生类组合而成的。其中,View是所有UI组件的基类,而ViewGroup是容纳这些组件的容器,其本身也是从View派生出来的。AndroidUI界面的一般结构可参见:
可见,作为容器的ViewGroup可以包含作为叶子节点的View,也可以包含作为更低层次的子ViewGroup,而子ViewGroup又可以包含下一层的叶子节点的View和ViewGroup。事实上,这种灵活的View层次结构可以形成非常复杂的UI布局,开发者可据此设计、开发非常精致的UI界面。一般来说,开发Android应用程序的UI界面都不会直接实用View和ViewGroup,而是使用这两大基类的派生类。下面我们列举了android中View和ViewGroup的派生类。
View派生出的直接子类有:AnalogClock,ImageView,KeyboardView, ProgressBar,SurfaceView,TextView,ViewGroup,ViewStub
View派生出的间接子类有:AbsListView,AbsSeekBar, AbsSpinner, AbsoluteLayout, AdapterView《T extends Adapter》,AdapterViewAnimator, AdapterViewFlipper, AppWidgetHostView, AutoCompleteTextView,Button,CalendarView, CheckBox, CheckedTextView, Chronometer, CompoundButton,
ViewGroup派生出的直接子类有:AbsoluteLayout,AdapterView《T extends Adapter》,FragmentBreadCrumbs,FrameLayout,LinearLayout,RelativeLayout,SlidingDrawer
ViewGroup派生出的间接子类有:AbsListView,AbsSpinner, AdapterViewAnimator, AdapterViewFlipper, AppWidgetHostView, CalendarView, DatePicker, DialerFilter, ExpandableListView, Gallery, GestureOverlayView,GridView,HorizontalScrollView, ImageSwitcher,ListView。
可以在秒秒学上看看Android的课程,讲解的可以,希望对你有帮助。
更多文章:
xml文件怎么转换成pdf文件(xml格式的word文档怎么转换为pdf,或者xml格式的word怎么转换成word格式的)
2024年5月18日 07:17
霹雳大喇叭里面王祖贤爸妈的扮演者是谁?霹雳大喇叭演员joanne的母亲的演员是谁
2024年7月6日 16:56
datepicker指定可选日期(jquery.datepicker怎么指定日期为每个月最后一天)
2024年7月8日 06:30
proposal词根词缀(请教purpose 的词根词缀 和 词根pose系列单词的意思)
2024年8月12日 13:15
win7 powershell下载(怎么在win7系统上下载xboxgamebar)
2024年9月1日 00:10
discuz免费移动端模板(MUED(www.visds.com)上的discuz x2免费模板怎样)
2024年7月13日 10:17
表格trim函数(excel表格中卡号数字后面的空格怎么一起删除)
2024年8月27日 03:10
c语言round函数怎么用(C语言问题,这里怎么实现四舍五入的啊)
2024年7月12日 14:30
微信小程序和原生APP比起来有什么优势?相比阿里云的飞天系统,腾讯云用的是什么系统
2024年7月15日 07:33
404 not found nginx是什么(404 NOT FOUNT nginx什么意思)
2024年7月14日 01:24
mysql存储过程返回(mybatis调用mysql存储过程(返回参数,单结果集,多结果集))
2024年8月31日 04:45