Android学习自定义View(一)——初识View

简介: MainActivity如下: package cc.testviewstudy1;import android.os.Bundle;import android.

MainActivity如下:

package cc.testviewstudy1;

import android.os.Bundle;
import android.app.Activity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewParent;
import android.widget.RelativeLayout;
/**
 * Demo描述:
 * 关于自定义View的学习(一)
 * 
 * 学习资料:
 * http://blog.csdn.net/guolin_blog/article/details/12921889
 * Thank you very much
 *
 */
public class MainActivity extends Activity {
    private RelativeLayout mRelativeLayout;
    private LayoutInflater mLayoutInflater;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		init();
		//test1();
		test2();
		test3();
	}
	
	
	//每个Activity由两部分组成.
	//1 title
	//2 contentView
	//我们可以分别设置它们
	private void init(){
		setTitle("This is title");
		setContentView(R.layout.main);
	}
	
	
	
	
	//用button_layout_wrong布局的方式来在View中新加一个Button
	//是不够准确的.因为此时我们是无法通过 android:layout_width和 android:layout_height
	//指定Button的宽和高,最终Button显示的只有wrap_content的大小.
	private void test1(){
		mRelativeLayout=(RelativeLayout) findViewById(R.id.relativeLayout);
		mLayoutInflater=LayoutInflater.from(MainActivity.this);
		View buttonView=mLayoutInflater.inflate(R.layout.button_layout_wrong, null);
		mRelativeLayout.addView(buttonView);
	}
	
	//怎么解决test1中的问题呢?
	//关键在于android:layout_width和 android:layout_height的理解
	//它指的是的控件在布局中的宽和高所以叫android:layout_width和 android:layout_height
	//而不是叫android:width和 android:height.
	//所以,我们要先把控件放在一个布局里面,然后再给该控件指定宽和高.这样才有效果.
	//如:button_layout_right所示
	private void test2(){
		mRelativeLayout=(RelativeLayout) findViewById(R.id.relativeLayout);
		mLayoutInflater=LayoutInflater.from(MainActivity.this);
		View buttonView=mLayoutInflater.inflate(R.layout.button_layout_right, null);
		mRelativeLayout.addView(buttonView);
	}
	
	
	
	//继续上面的例子:
	//我们在每次布局的时候不是可以在最外层的布局通过android:layout_width和 android:layout_height
	//来指定该布局的宽和高么然后setContentView()将其显示在屏幕上的么?
	//这个最大的View没有再嵌套一层布局为什么可以指定宽和高呢?
	//这不是和上面的例子冲突了么?
	//其实,不是的.
	//因为在加载每个布局文件xml的时候.不论其根布局是什么,都会将该布局
	//外面嵌套一层FrameLayout.
	//这样就和上面的例子统一了.
	private void test3(){
		mRelativeLayout=(RelativeLayout) findViewById(R.id.relativeLayout);
		ViewParent viewParent=mRelativeLayout.getParent();
		System.out.println("每个布局文件的最外层的实质是:"+viewParent);
	}
		

}


main.xml如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/relativeLayout"
   >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/hello_world" 
        android:layout_centerInParent="true"
    />

</RelativeLayout>


button_layout_wrong.xml如下:

<Button xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="200dp"
    android:layout_height="20dp"
    android:textSize="30sp"
    android:text="Button" >

</Button>

button_layout_right.xml如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <Button
        android:layout_width="200dp"
        android:layout_height="200dp"
        android:text="Button" 
        android:textSize="30sp">
    </Button>
</RelativeLayout>



相关文章
|
4月前
|
Android开发 UED 计算机视觉
Android自定义view之线条等待动画(灵感来源:金铲铲之战)
本文介绍了一款受游戏“金铲铲之战”启发的Android自定义View——线条等待动画的实现过程。通过将布局分为10份,利用`onSizeChanged`测量最小长度,并借助画笔绘制动态线条,实现渐变伸缩效果。动画逻辑通过四个变量控制线条的增长与回退,最终形成流畅的等待动画。代码中详细展示了画笔初始化、线条绘制及动画更新的核心步骤,并提供完整源码供参考。此动画适用于加载场景,提升用户体验。
399 5
Android自定义view之线条等待动画(灵感来源:金铲铲之战)
|
4月前
|
XML Java Android开发
Android自定义view之网易云推荐歌单界面
本文详细介绍了如何通过自定义View实现网易云音乐推荐歌单界面的效果。首先,作者自定义了一个圆角图片控件`MellowImageView`,用于绘制圆角矩形图片。接着,通过将布局放入`HorizontalScrollView`中,实现了左右滑动功能,并使用`ViewFlipper`添加图片切换动画效果。文章提供了完整的代码示例,包括XML布局、动画文件和Java代码,最终展示了实现效果。此教程适合想了解自定义View和动画效果的开发者。
206 65
Android自定义view之网易云推荐歌单界面
|
4月前
|
XML 前端开发 Android开发
一篇文章带你走近Android自定义view
这是一篇关于Android自定义View的全面教程,涵盖从基础到进阶的知识点。文章首先讲解了自定义View的必要性及简单实现(如通过三个构造函数解决焦点问题),接着深入探讨Canvas绘图、自定义属性设置、动画实现等内容。还提供了具体案例,如跑马灯、折线图、太极图等。此外,文章详细解析了View绘制流程(measure、layout、draw)和事件分发机制。最后延伸至SurfaceView、GLSurfaceView、SVG动画等高级主题,并附带GitHub案例供实践。适合希望深入理解Android自定义View的开发者学习参考。
497 84
|
4月前
|
前端开发 Android开发 UED
讲讲Android为自定义view提供的SurfaceView
本文详细介绍了Android中自定义View时使用SurfaceView的必要性和实现方式。首先分析了在复杂绘制逻辑和高频界面更新场景下,传统View可能引发卡顿的问题,进而引出SurfaceView作为解决方案。文章通过Android官方Demo展示了SurfaceView的基本用法,包括实现`SurfaceHolder.Callback2`接口、与Activity生命周期绑定、子线程中使用`lockCanvas()`和`unlockCanvasAndPost()`方法完成绘图操作。
102 3
|
前端开发 Java Android开发
|
2月前
|
安全 数据库 Android开发
在Android开发中实现两个Intent跳转及数据交换的方法
总结上述内容,在Android开发中,Intent不仅是活动跳转的桥梁,也是两个活动之间进行数据交换的媒介。运用Intent传递数据时需注意数据类型、传输大小限制以及安全性问题的处理,以确保应用的健壯性和安全性。
143 11
|
6月前
|
JavaScript Linux 网络安全
Termux安卓终端美化与开发实战:从下载到插件优化,小白也能玩转Linux
Termux是一款安卓平台上的开源终端模拟器,支持apt包管理、SSH连接及Python/Node.js/C++开发环境搭建,被誉为“手机上的Linux系统”。其特点包括零ROOT权限、跨平台开发和强大扩展性。本文详细介绍其安装准备、基础与高级环境配置、必备插件推荐、常见问题解决方法以及延伸学习资源,帮助用户充分利用Termux进行开发与学习。适用于Android 7+设备,原创内容转载请注明来源。
1192 77
|
3月前
|
安全 Java Android开发
为什么大厂要求安卓开发者掌握Kotlin和Jetpack?深度解析现代Android开发生态优雅草卓伊凡
为什么大厂要求安卓开发者掌握Kotlin和Jetpack?深度解析现代Android开发生态优雅草卓伊凡
165 0
为什么大厂要求安卓开发者掌握Kotlin和Jetpack?深度解析现代Android开发生态优雅草卓伊凡
|
7月前
|
前端开发 Java Shell
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
413 20
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex