- 浏览: 38821 次
- 性别:
- 来自: 河北保定
最新评论
-
jianweicao:
楼主能给个例子否?
android在textview里首行缩进最简单方法 -
liu_zheng:
博主 怎么嵌套 能给个示例么?
android在textview里首行缩进最简单方法 -
huangyisheng0203:
我想说的是,真的太感谢你了。
android中引用项目出现红色大感叹号的问题解决方法
很多时候android自定义控件并不克不及满足需求,如何做呢?很多办法,可以本身绘制一个,可以经由过程持续根蒂根基控件来重写某些环节,当然也可以将控件组合成一个新控件,这也是最便利的一个办法。今天就来介绍下如何应用组合控件,将经由过程两个实例来介绍。
第一个实现一个带图片和文字的按钮,如图所示:
全部过程可以分四步走。第一步,定义一个layout,实现按钮内部的布局。代码如下:
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="fill_parent" android:layout_height="fill_parent" ><ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/iv" android:src="@drawable/confirm" android:paddingTop="5dip" android:paddingBottom="5dip" android:paddingLeft="40dip" android:layout_gravity="center_vertical" /><TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="断定" android:textColor="#000000" android:id="@+id/tv" android:layout_marginLeft="8dip" android:layout_gravity="center_vertical" /></LinearLayout>
这个xml实现一个左图右字的布局,接下来写一个类持续LinearLayout,导入方才的布局,并且设置须要的办法,从而使的能在代码中把握这个自定义控件内容的显示。代码如下:
package com.notice.ib;
import android.content.Context;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
public class ImageBt extends LinearLayout {
private ImageView iv;
private TextView tv;
public ImageBt(Context context) {
this(context, null);
}
public ImageBt(Context context, AttributeSet attrs) {
super(context, attrs);
// 导入布局
LayoutInflater.(context).inflate(R.layout.custombt, this, true);
iv = (ImageView) findViewById(R.id.iv);
tv = (TextView) findViewById(R.id.tv);
}
/** * 设置图片资料 */
public void setImageResource(int resId) {
iv.setImageResource(resId);
}
/** * 设置显示的文字 */
public void setTextViewText(String text) {
tv.setText(text); }}
第三步,在须要应用这个自定义控件的layout中参加这控件,只须要在xml中参加即可。办法如下:
<RelativeLayout
android:orientation="horizontal" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_gravity="bottom" > <com.notice.ib.ImageBt
android:id="@+id/bt_confirm" android:layout_height="wrap_content" android:layout_width="wrap_content" android:layout_alignParentBottom="true" android:background="@drawable/btbg" android:clickable="true" android:focusable="true"
/>
<com.notice.ib.ImageBt
android:id="@+id/bt_cancel"
android:layout_toRightOf="@id/bt_confirm" android:layout_height="wrap_content" android:layout_width="wrap_content" android:layout_alignParentBottom="true" android:background="@drawable/btbg" android:clickable="true" android:focusable="true" />
</RelativeLayout>
重视的是,控件标签应用完全的类名即可。为了给按钮一个点击结果,你须要给他一个or靠山,这里就不说了。
最后一步,即在activity中设置该控件的内容。当然,在xml中也可以设置,然则只能设置一个,当我们须要两次应用如许的控件,并且显示内容不应时就不可了。在activity中设置也很是简单,我们在ImageBt这个类中已经写好了响应的办法,简单调用即可。代码如下:
public class MainActivity extends Activity {
private ImageBt ib1;
private ImageBt ib2;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState);
setContentView(R.layout.login);
ib1 = (ImageBt) findViewById(R.id.bt_confirm);
ib2 = (ImageBt) findViewById(R.id.bt_cancel); ib1.setTextViewText("断定");
ib1.setImageResource(R.drawable.confirm);
ib2.setTextViewText("作废");
ib2.setImageResource(R.drawable.cancel); ib1.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
//在这里可以实现点击事务
}
});
}}
如许,一个带文字和图片的组合按钮控件就完成了。如许梳理一下,应用还是很是简单的。组合控件能做的事还很是多,主如果在类似上例中的ImageBt类中写好要应用的办法即可。
再来看一个组合控件,带删除按钮的EidtText。即在用户输入后,会呈现删除按钮,点击即可作废用户输入。
定义办法和上例一样。起首写一个自定义控件的布局:
<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" >
<EditText android:id="@+id/et" android:layout_width="fill_parent" android:layout_height="wrap_content" android:singleLine="true" />
<ImageButton android:id="@+id/ib"
android:visibility="gone"
android:src="@drawable/menu_" android:layout_width="wrap_content" android:layout_height="wrap_content"
android:background="#00000000"
android:layout_alignRight="@+id/et" />
</RelativeLayout>
实现输入框右侧带按钮结果,重视将按钮隐蔽。然后写一个EditCancel类,实现删除用户输入功能。这里用到了TextWatch这个接口,监听输入框中的文字变更。应用也很简单,实现他的三个办法即可。看代码:
package com.notice.ce;
import android.content.Context;
import android.text.Editable;
import android.text.TextWatcher;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.EditText;
import android.widget.ImageButton;
import android.widget.LinearLayout;
public class EditCancel extends LinearLayout implements EdtInterface {
ImageButton ib;
EditText et;
public EditCancel(Context context) {
super(context);
}
public EditCancel(Context context, AttributeSet attrs) { super(context, attrs);
LayoutInflater.(context).inflate(R.layout.custom_editview, this, true);
init();
}
private void init() {
ib = (ImageButton) findViewById(R.id.ib);
et = (EditText) findViewById(R.id.et); et.addTextChangedListener(tw);
// 为输入框绑定一个监听文字变更的****
// 添加按钮点击事务
ib.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
hideBtn();
// 隐蔽按钮
et.setText("");
// 设置输入框内容为空
}
});
}
// 当输入框状况改变时,会调用响应的办法
TextWatcher tw = new TextWatcher() {
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
// TODO Auto-generated method stub }
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
// TODO Auto-generated method stub
}
// 在文字改变后调用
@Override
public void afterTextChanged(Editable s) { if (s.length() == 0) {
hideBtn();// 隐蔽按钮
} else {
showBtn();// 显示按钮
}
}
};
@Override public void hideBtn() {
// 设置按钮不成见
if (ib.isShown()) ib.setVisibility(View.GONE);
}
@Override
public void showBtn() {
// 设置按钮可见
if (!ib.isShown()) ib.setVisibility(View.VISIBLE);
}}interface EdtInterface {
public void hideBtn();
public void showBtn();}
在TextWatch接口的afterTextChanged办法中对文字进行断定,若长度为0,就隐蔽按钮,不然,显示按钮。
别的,实现ImageButton(即那个叉)的点击事务,删除输入框中的内容,并隐蔽按钮。
第一个实现一个带图片和文字的按钮,如图所示:
全部过程可以分四步走。第一步,定义一个layout,实现按钮内部的布局。代码如下:
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="fill_parent" android:layout_height="fill_parent" ><ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/iv" android:src="@drawable/confirm" android:paddingTop="5dip" android:paddingBottom="5dip" android:paddingLeft="40dip" android:layout_gravity="center_vertical" /><TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="断定" android:textColor="#000000" android:id="@+id/tv" android:layout_marginLeft="8dip" android:layout_gravity="center_vertical" /></LinearLayout>
这个xml实现一个左图右字的布局,接下来写一个类持续LinearLayout,导入方才的布局,并且设置须要的办法,从而使的能在代码中把握这个自定义控件内容的显示。代码如下:
package com.notice.ib;
import android.content.Context;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
public class ImageBt extends LinearLayout {
private ImageView iv;
private TextView tv;
public ImageBt(Context context) {
this(context, null);
}
public ImageBt(Context context, AttributeSet attrs) {
super(context, attrs);
// 导入布局
LayoutInflater.(context).inflate(R.layout.custombt, this, true);
iv = (ImageView) findViewById(R.id.iv);
tv = (TextView) findViewById(R.id.tv);
}
/** * 设置图片资料 */
public void setImageResource(int resId) {
iv.setImageResource(resId);
}
/** * 设置显示的文字 */
public void setTextViewText(String text) {
tv.setText(text); }}
第三步,在须要应用这个自定义控件的layout中参加这控件,只须要在xml中参加即可。办法如下:
<RelativeLayout
android:orientation="horizontal" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_gravity="bottom" > <com.notice.ib.ImageBt
android:id="@+id/bt_confirm" android:layout_height="wrap_content" android:layout_width="wrap_content" android:layout_alignParentBottom="true" android:background="@drawable/btbg" android:clickable="true" android:focusable="true"
/>
<com.notice.ib.ImageBt
android:id="@+id/bt_cancel"
android:layout_toRightOf="@id/bt_confirm" android:layout_height="wrap_content" android:layout_width="wrap_content" android:layout_alignParentBottom="true" android:background="@drawable/btbg" android:clickable="true" android:focusable="true" />
</RelativeLayout>
重视的是,控件标签应用完全的类名即可。为了给按钮一个点击结果,你须要给他一个or靠山,这里就不说了。
最后一步,即在activity中设置该控件的内容。当然,在xml中也可以设置,然则只能设置一个,当我们须要两次应用如许的控件,并且显示内容不应时就不可了。在activity中设置也很是简单,我们在ImageBt这个类中已经写好了响应的办法,简单调用即可。代码如下:
public class MainActivity extends Activity {
private ImageBt ib1;
private ImageBt ib2;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState);
setContentView(R.layout.login);
ib1 = (ImageBt) findViewById(R.id.bt_confirm);
ib2 = (ImageBt) findViewById(R.id.bt_cancel); ib1.setTextViewText("断定");
ib1.setImageResource(R.drawable.confirm);
ib2.setTextViewText("作废");
ib2.setImageResource(R.drawable.cancel); ib1.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
//在这里可以实现点击事务
}
});
}}
如许,一个带文字和图片的组合按钮控件就完成了。如许梳理一下,应用还是很是简单的。组合控件能做的事还很是多,主如果在类似上例中的ImageBt类中写好要应用的办法即可。
再来看一个组合控件,带删除按钮的EidtText。即在用户输入后,会呈现删除按钮,点击即可作废用户输入。
定义办法和上例一样。起首写一个自定义控件的布局:
<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" >
<EditText android:id="@+id/et" android:layout_width="fill_parent" android:layout_height="wrap_content" android:singleLine="true" />
<ImageButton android:id="@+id/ib"
android:visibility="gone"
android:src="@drawable/menu_" android:layout_width="wrap_content" android:layout_height="wrap_content"
android:background="#00000000"
android:layout_alignRight="@+id/et" />
</RelativeLayout>
实现输入框右侧带按钮结果,重视将按钮隐蔽。然后写一个EditCancel类,实现删除用户输入功能。这里用到了TextWatch这个接口,监听输入框中的文字变更。应用也很简单,实现他的三个办法即可。看代码:
package com.notice.ce;
import android.content.Context;
import android.text.Editable;
import android.text.TextWatcher;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.EditText;
import android.widget.ImageButton;
import android.widget.LinearLayout;
public class EditCancel extends LinearLayout implements EdtInterface {
ImageButton ib;
EditText et;
public EditCancel(Context context) {
super(context);
}
public EditCancel(Context context, AttributeSet attrs) { super(context, attrs);
LayoutInflater.(context).inflate(R.layout.custom_editview, this, true);
init();
}
private void init() {
ib = (ImageButton) findViewById(R.id.ib);
et = (EditText) findViewById(R.id.et); et.addTextChangedListener(tw);
// 为输入框绑定一个监听文字变更的****
// 添加按钮点击事务
ib.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
hideBtn();
// 隐蔽按钮
et.setText("");
// 设置输入框内容为空
}
});
}
// 当输入框状况改变时,会调用响应的办法
TextWatcher tw = new TextWatcher() {
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
// TODO Auto-generated method stub }
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
// TODO Auto-generated method stub
}
// 在文字改变后调用
@Override
public void afterTextChanged(Editable s) { if (s.length() == 0) {
hideBtn();// 隐蔽按钮
} else {
showBtn();// 显示按钮
}
}
};
@Override public void hideBtn() {
// 设置按钮不成见
if (ib.isShown()) ib.setVisibility(View.GONE);
}
@Override
public void showBtn() {
// 设置按钮可见
if (!ib.isShown()) ib.setVisibility(View.VISIBLE);
}}interface EdtInterface {
public void hideBtn();
public void showBtn();}
在TextWatch接口的afterTextChanged办法中对文字进行断定,若长度为0,就隐蔽按钮,不然,显示按钮。
别的,实现ImageButton(即那个叉)的点击事务,删除输入框中的内容,并隐蔽按钮。
发表评论
-
关于android中出现"ADB server didn't ACK"这个问题解决方案
2012-09-12 09:39 882假如,打开eclipse出现"ADB server ... -
Intent和IntentFilter详解
2012-09-10 10:53 758Intent用于启动Activity,Serv ... -
android 广播机制
2012-08-31 09:48 784流程:1.需要写一个继承广播的类,TextReceiver。 ... -
Android的Handler总结
2012-08-22 09:58 742一、Handler的定义: ... -
eclipse导入的Android项目没有android.jar包并报错
2012-08-20 11:08 878选择这个android项目右击" Propertie ... -
android 如何全部关闭activity。
2012-08-20 11:07 1212如何退出Activity?如何安 ... -
在公共类定义全局变量引用
2012-08-15 07:56 829//字符串 public static String = & ... -
android在textview里首行缩进最简单方法
2012-07-31 11:07 7435用string定义文字,然后再文字外嵌套一个“ "& ... -
android listview间隔线颜色
2012-07-27 15:34 2428首先设置颜色 android:divider="#d ... -
android seekbar定义高度
2012-07-26 10:34 2750用SeekBar,并设置属性style="?andr ... -
android 重写adpter
2012-07-24 07:40 899重写系统的simpleadpter: public class ... -
android中 4张图片在底部排列,适用各种分辨率
2012-07-10 07:55 972android:layout_weight="1&q ... -
android里设置图片透明。
2012-07-05 17:26 1131设置两张图片。 <ImageView ... -
android下载问题。本地与网络资源大小不一致解决方法
2012-07-04 09:02 839之前的代码:如下 output = new FileOutpu ... -
白话Android 四种Activity的加载模式
2012-06-04 09:25 921“拿来主义”standard模式。哪里需要调用我我就去哪里 ... -
Activity启动模式小总结
2012-05-22 16:22 999standard 每次都会新建,每个Task都可以有,且每个 ... -
Android 四种Activity的加载模式
2012-05-22 10:12 1157一个Activty的生命周期 Ac ... -
Android单线程模型
2012-03-26 11:10 1206单线程模型 当一个程序第一次启动时,Android会同时启动 ... -
Android应用的基本组件
2012-03-06 16:29 9491.Activity 是android应用中负责与用户交互的组 ... -
Android Java包
2012-03-05 23:51 831快速了解android平台的一种方式是查看Java包的结构。 ...
相关推荐
本实验二“android-UI控件”深入探讨了Android平台上的各种UI组件及其用法,旨在帮助开发者创建功能丰富的、用户体验良好的应用程序。 首先,Android提供了多种基础控件,如TextView、EditText、Button、ImageView...
本文将深入探讨Android自定义控件的概念、重要性以及如何通过重写已有控件来扩展其功能,帮助开发者从初阶迈进高阶。 首先,我们了解什么是自定义控件。在Android系统中,预置了大量的标准控件,如Button、TextView...
本篇将深入探讨Android UI控件的各个方面,旨在提供一个全面的概述。 1. **基础控件** Android的基础UI控件包括TextView(用于显示文本)、EditText(用于用户输入文本)、Button(用于点击操作)、ImageView...
本压缩包文件包含了"Android-UI控件16、17集"的源码,这为我们提供了深入学习和理解Android UI控件设计和实现的宝贵材料。 16集中可能涉及的知识点: - **自定义View**:Android系统提供了许多预定义的视图,但...
在Android Studio中,我们可以编写单元测试、UI测试等来确保自定义控件的正确性和性能。测试代码通常位于`src/test/java`或`src/androidTest/java`目录下,使用JUnit或Espresso等框架编写。 总的来说,Android的...
在Android应用开发中,UI控件的设计和实现是至关重要的,因为它们直接影响到用户的交互体验。本主题聚焦于“Android动态的时速表UI控件”,这是一个专为Android平台设计的自定义视图,用于创建类似汽车时速表的用户...
在这个例子中,我们将几个原生的控件组合在一起,形成一个全新的控件,这样不仅可以简化代码,还能使UI设计更加灵活。 自定义组合控件的过程主要包括以下步骤: 1. **选择基础控件**:首先,我们需要确定要组合的...
在Android开发中,UI(用户界面)是至关重要的部分,因为它直接影响到用户的体验。本资料“Android_UI.rar”聚焦于Android平台上的基本UI组件及其在GIS(地理信息系统)中的应用,同时也涉及到Java编程语言。以下将...
作为初学者,理解并掌握Android UI设计的基本原则和控件使用方法是踏入移动应用开发大门的关键步骤。 Android UI设计的核心是布局管理器(Layout Manager),它们决定了控件在屏幕上的排列方式。常见的布局管理器有...
本篇文章将深入探讨一些实用的Android UI控件应用技巧,帮助开发者提升APP的用户体验。 1. **布局管理**:Android提供了多种布局管理器,如线性布局(LinearLayout)、相对布局(RelativeLayout)、帧布局...
这份"Android嵌入式开发资料"包含了Android UI控件的使用、应用程序开发以及在Android系统下绘制2D图形的实践项目。接下来,我们将深入探讨这些主题。 首先,Android UI(用户界面)控件是构建应用程序的基础,它们...
本文将深入探讨如何在Android中创建自定义组合控件以及重写现有控件,并通过具体例子源码来帮助初学者理解这一过程。 首先,让我们了解什么是自定义View。在Android中,我们通常使用的诸如Button、TextView等都是...
下面,我们将深入探讨Android UI控件和库的相关知识。 1. **基础UI控件**:Android SDK提供了丰富的预定义控件,如Button、EditText、TextView、ImageView、RadioButton、CheckBox等。这些控件构成了Android应用的...
在Android开发中,自定义...无论是组合控件还是重写控件,都需要对Android的UI框架有深入的理解,才能创建出既美观又实用的自定义组件。通过不断实践和优化,开发者可以打造出独一无二的应用界面,提升应用的整体品质。
1. **Android控件**:Android系统提供了丰富的UI控件,如TextView(文本显示)、Button(按钮)、EditText(文本输入)、ImageView(图片显示)、CheckBox(复选框)、RadioButton(单选按钮)、Spinner(下拉列表)...
在Android应用开发中,网络请求和UI控件的动态修改是两个非常重要的环节。本实训主要探讨如何在Android环境中利用Java编程实现网络数据的获取,并将这些数据实时更新到用户界面上,提升用户体验。以下是对这两个核心...
在Android开发中,UI控件是构建用户界面的基础元素,它们负责展示信息并接收用户的交互。这个名为"一个项目看遍所有UI控件Android源码"的压缩包资源,显然是为了帮助开发者深入理解Android UI控件的工作原理和内部...
在Android中,自定义控件主要通过继承已有的View或ViewGroup类,然后重写其onDraw()方法来实现自定义的绘制逻辑。GaugeView控件很可能就是基于这样的机制构建的,通过精准控制画布(Canvas)上的线条、弧度和颜色,...
在Android开发中,控件重写(View重写)是一项重要的技术,它允许开发者自定义UI组件,以满足特定的设计需求或实现独特的交互效果。本文将深入探讨Android控件重写的核心概念、步骤以及如何通过代码实现。 首先,...
Android SDK提供了丰富的UI控件,如TextView、Button、EditText、ImageView等,这些控件可以通过XML布局文件或者代码动态添加。 1. **TextView**:用于显示文本,可设置字体、颜色、大小等样式。 2. **Button**:...