|
Android中View组件的作用类似于Swing变成中的JPanel,它只是一个空白的矩形区域,View组件中没有任何内容。对于Android应用的其他UI组件来说,它们都继承了View组件,然后在View组件提供的空白区域绘制外观。
当Android系统提供的UI组件不足以满足项目需求时,我们可以通过继承View并重写View类的一个或多个方法来自定义组件。
通常可以被用户重写的方法如下:
1.构造器:重写构造器是定制View的最基本的方式,当Java(或Kotlin)代码创建一个View实例或根据XML布局文件加载并构建界面时将调用该构造器。
2.onFinishInflate():这是一个回调方法,当应用从XML布局文件加载该组件并利用它来构建界面之后,该方法将会被调用。
3.onMeasure(int,int):调用该方法来检测View组件及其所包含的所有子组件的大小。
4.onLayout(boolean,int,int,int,int):当该组件需要分配其子组件的位置、大小时,该方法就会被回调。
5.onSizeChanged(int,int,int,int):当该组件的大小被改变时回调该方法。
6.onDraw(Canvas):当该组件将要绘制它的内容时回调该方法。
7.onKeyDown(int,KeyEvent):当按下某个键时触发该方法。
8.onKeyUp(int,KeyEvent):当松开某个键时触发该方法。
9.onTrackballEvent(MotionEvent):当发生轨迹球事件时触发该方法
10.onTouchEvent(MotionEvent):当发生触摸屏事件时触发该方法
11.onFocusChanged(boolean gainFocus,int direction,Rect previouslyFocusedRect):当该组件焦点发生改变时触发该方法。
12.onWindowFocusChanged(boolean):当包含该组件的窗口失去或得到焦点时触发该方法。
13.onAttachedToWindow():当把该组件放入某个窗口中时触发该方法
14.onDetachedFromWindow():当把该组件从某个窗口中分离时触发该方法
15.onWindowVisibilityChanged(int):当包含该组件的窗口的可见性发生改变时触发该方法。
当我们在开发自定义View时,通常仅需根据业务需求重写上面的部分方法,如果自定义组件仅仅只是组合现有的组件那就更加简单了,仅仅实现自定义组件的构造器然后使用LayoutInflater加载布局文件即可。
⒈实例自定义View
1 package cn.coreqi.view;
2
3 import android.content.Context;
4 import android.graphics.Canvas;
5 import android.graphics.Color;
6 import android.graphics.Paint;
7 import android.util.AttributeSet;
8 import android.view.MotionEvent;
9 import android.view.View;
10
11 public class DrawView extends View {
12 private float currentX = 40f;
13 private float currentY = 50f;
14
15 //定义并创建画笔
16 private Paint p = new Paint();
17
18 public DrawView(Context context) {
19 super(context);
20 }
21
22 public DrawView(Context context, AttributeSet attrs) {
23 super(context, attrs);
24 }
25
26 //当该组件将要绘制它的内容时触发该方法
27 @Override
28 protected void onDraw(Canvas canvas) {
29 super.onDraw(canvas);
30 //设置画笔的颜色
31 p.setColor(Color.RED);
32 //绘制一个小圆(作为小球)
33 canvas.drawCircle(currentX,currentY,15F,p);
34 }
35
36 //为该组件的触碰事件重写事件处理方法
37 @Override
38 public boolean onTouchEvent(MotionEvent event) {
39 //修改currentX,currentY两个成员变量
40 currentX = event.getX();
41 currentY = event.getY();
42 //通知当前组件重新绘制自己
43 invalidate();
44 //返回true表明该处理方法已经处理该事件
45 return true;
46 }
47 }
⒉在代码中创建自定义View
1 package cn.coreqi;
2
3 import androidx.appcompat.app.AppCompatActivity;
4
5 import android.os.Bundle;
6 import android.widget.LinearLayout;
7 import cn.coreqi.view.DrawView;
8
9
10 public class MainActivity extends AppCompatActivity {
11
12 @Override
13 protected void onCreate(Bundle savedInstanceState) {
14 super.onCreate(savedInstanceState);
15 //新建LinearLayout布局容器
16 LinearLayout layout = new LinearLayout(this);
17 //设置该Activity显示layout
18 setContentView(layout);
19 //创建我们自定义的View组件
20 DrawView draw = new DrawView(this);
21 //设置自定义组件的最小宽度、高度
22 draw.setMinimumWidth(300);
23 draw.setMinimumHeight(500);
24 layout.addView(draw);
25 }
26 }
⒊在XML布局文件中创建自定义View
1 <?xml version="1.0" encoding="utf-8"?>
2 <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
3 xmlns:app="http://schemas.android.com/apk/res-auto"
4 xmlns:tools="http://schemas.android.com/tools"
5 android:layout_width="match_parent"
6 android:layout_height="match_parent"
7 tools:context=".MainActivity">
8
9 <cn.coreqi.view.DrawView
10 android:id="@+id/drawView"
11 android:layout_width="match_parent"
12 android:layout_height="match_parent" />
13
14 </androidx.constraintlayout.widget.ConstraintLayout>
来源:https://www.cnblogs.com/fanqisoft/p/11017395.html |