Android View中的控件和监听方法...
PS:居然三天没写博客了...今天补上...东西虽多,但是都是一些基础...代码多了一些,有人可能会这样问,粘这么多代码有毛用..其实对于一个Android的初学者来说,一个完整的代码是最容易帮助理解的...我也是在一点一点的去学习...看了许多人的博客,大部分都是粘贴部分代码,说实话,刚接触的时候真的感觉不是很好理解...不知道其他地方如何去实现..只能自己慢慢的去摸索..我写的这东西也不是给大神们去看的...大神一看就能明白怎么回事..因此我是站在初学者的立场上,才贴了这么多的代码...好了,不废话了...
学习内容:
1.基本控件的应用...
2.如何为组件绑定监听事件...
i.Button 与 TextView组件与监听事件 OnClickListener()
在这里我还是多用例子进行讲解,还是比较清晰的...
这是xml文件:
<!--这里定义了四个组件,三个按钮,一个文本显示显示组件..只是一些简单的布局,没什么新的东西,因此也就没有必要讲了,大家看看其实就懂..-->
<?xml version="1.0" encoding="utf-8"?>
<Linearlayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center"
android:orientation="vertical" > <textview
android:id="@+id/TextView01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginbottom="10dp"
android:text="杜鹃不啼,如何让它啼?"
android:textsize="20sp" >
</textview> <button
android:id="@+id/Button01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="杀之不足惜!"
android:textsize="20sp" >
</button> <button
android:id="@+id/Button02"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="诱之自然啼!"
android:textsize="20sp" >
</button> <button
android:id="@+id/Button03"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="待之莫须急!"
android:textsize="20sp" >
</button>
</Linearlayout>
下面是src下的MainActivity.java文件..比较简单...没什么难的东西...就是唯一在内部实现的时候大家有可能有点不太理解..
package com.example.android_view; import android.os.Bundle;
import android.widget.Button;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickLisener; //OnClickListener是View的内部接口..
import android.widget.TextView;
public class MainHelloButton extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main); // 实现一个多按钮可用的单击监听器对象,这个地方是在内部实现这个方法..只要点击了按钮,那么就会触发这个事件...
OnClickListener listener = new Button.OnClickListener() {
@Override
public void onClick(View v) {
setTitle("您的答案是:" + ((TextView) v).getText()); //这个地方可以使用setTitle方法将获取的字符串显示在TextView上...
}
}; // 为界面中的每个按钮绑定上这个单击监听器
findViewById(R.id.Button01).setOnClickListener(listener);
findViewById(R.id.Button02).setOnClickListener(listener);
findViewById(R.id.Button03).setOnClickListener(listener);
}
}
  在这里再说一下TextView,TextView是一个文本显示组件..很常用的一个组件,TextView类被很多的组件类去直接继承或者是间接继承..像Button,EditText,CheckBox,RadioButton等等都是继承了TextView类..TextView是一个非常重要的地方..再举一个例子来深入理解...
<?xml version="1.0" encoding="utf-8"?> <!--<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent">这里也可以在TextView外面加入一层这个东西,也可以直接实现文本滚动..-->
<Linearlayout
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" > <textview
android:id="@+id/TextView01"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/hello"
android:textsize="30sp" >
</textview> </Linearlayout> <!--</ScrollView>-->
java文件...这里就很简单了...别忘我们还需要修改一下string.xml文本...
package android.basic.lesson9; import android.app.Activity;
import android.os.Bundle;
import android.text.method.ScrollingMovementMethod;
import android.widget.TextView; public class HelloTextView extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main); // 找到TextView组件
TextView tv = (TextView) findViewById(R.id.TextView01); // 设置移动方法
tv.setMovementMethod(ScrollingMovementMethod.getInstance());
}
}
ii.EditText..可编辑的文本显示组件..
布局文件就放这一个控件就可以了...
<?xml version="1.0" encoding="utf-8"?>
<Linearlayout
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" > <EditText
android:id="@+id/TextView01"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/hello"
android:textsize="30sp" >
</EditText> </Linearlayout>
package android.basic.lesson9; import android.app.Activity;
import android.os.Bundle;
import android.text.method.ScrollingMovementMethod;
import android.widget.TextView; public class HelloTextView extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
final EditText et = (EditText) findViewById(R.id.EditText01);
et.setOnKeyListener(new View.OnKeyListener() { @Override
public boolean onKey(View v, int keyCode, KeyEvent event) {
// 监视硬键盘按键
if (event.getAction() == KeyEvent.ACTION_DOWN && keyCode == KeyEvent.KEYCODE_ENTER) {
//这句话的意思其实就是当我们按下键盘的时候,获取到键盘的的输入值...
Toast.makeText(HelloTextView.this, et.getText(),Toast.LENGTH_SHORT).show();
// 返回true说明你已经处理了这个事件并且它应该就此终止,如果返回false就表示此事件还需要继续传递下去
return true;
}
return false;
}
}); }
}
  这个就是JAVA文件了..Toast是信息提示框组件..这里的HelloTextView表示的就是我们主函数,Toast.makeText()表示的是指定显示文本资源和信息的显示时间...大家可以试一下就可以理解这个东西的作用了..
iii.ImageButton和ImageView组件
ImageButton图片按钮...就是一个特殊的按钮而已...ImageView图片视图...二者在被点击的时候所产生的效果是不一样的...这里大家去试试就很容易发现了...
OnTouchListener()与OnClickListener()方法的区别...
<!--在使用图片组件的时候,一定要把图片导入到我们的drawable文件夹下面,否则会报错..-->
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<ImageButton
android:id="@+id/ImageButton01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/p1"
/>
<ImageView
android:id="@+id/ImageView01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/p2"/>
</LinearLayout>
java文件。。。
package android.basic.lesson9; import android.app.Activity;
import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnTouchListener;
import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.Toast; public class MainHelloImageButton extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
/*
* OnClickListener()当屏幕或者是其他组件被点击的时候触发..必须要有点击和松开两个事件..才被触发..
* OnTouchListener()这个表示的触碰屏幕或者组件的时候就会触发,有可能只是划过某一位置..就被触发..
* 这就二者的区别所在...
*/
// 找到xml中的ImageButton和ImageView
final ImageButton ib = (ImageButton) findViewById(R.id.ImageButton01);
final ImageView iv = (ImageView) findViewById(R.id.ImageView01); // 定义触摸监听
OnTouchListener otl = new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
switch (v.getId()) {
case R.id.ImageButton01:
Toast.makeText(getApplicationContext(),"触摸" + ((ImageView) v).getId(), Toast.LENGTH_LONG).show();
break;
case R.id.ImageView01:
Toast.makeText(getApplicationContext(),"触摸" + ((ImageView) v).getId(), Toast.LENGTH_LONG).show();
break;
}
return false;
}
}; // 定义点击监听
OnClickListener ocl = new OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(getApplicationContext(),"点击" + ((ImageView) v).getId(), Toast.LENGTH_LONG).show();
}
}; // 绑定监听
ib.setOnClickListener(ocl);
ib.setOnTouchListener(otl);
iv.setOnClickListener(ocl);
iv.setOnTouchListener(otl);
}
}
iv.CheckBox组件...
复选按钮...复选按钮估计大家也很熟悉,比如说在注册账号的时候就会有这个东西的出现...
OnClickListener()和OnCheckChangedListener()方法的区别...
这里添加了一个文本显示组件和两个复选框..复选框就代表可以一次选择多个...而单选框一次只能选择一个...
<?xml version="1.0" encoding="utf-8"?>
<linearlayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" > <textview
android:id="@+id/TextView01"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="选择你想得到的东西:" > <checkbox
android:id="@+id/CheckBox01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="苹果" >
</checkbox> <checkbox
android:id="@+id/CheckBox02"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="葡萄" >
</checkbox>
</textview> </linearlayout>
Java文件...这段代码说明了一下二者的区别...
package com.example.android_view;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.CompoundButton;
import android.widget.Toast;
import android.widget.CheckBox;
import android.widget.CompoundButton.OnCheckedChangeListener;
import android.widget.TextView;
public class MainActivity extends Activity {
private TextView TextView_01;
private CheckBox CheckBox_01;
private CheckBox CheckBox_02;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
TextView_1=(TextView)findViewById(R.id.TextView01);
CheckBox_1=(CheckBox)findViewById(R.id.CheckBox01);
CheckBox_2=(CheckBox)findViewById(R.id.ChechBox02);
/*OnClickListener()和OnCheckChangeListener()的区别在于:在复选框中,复选框的值不一定非要通过点击才能够进行选择
*直接调用setChecked也可以直接进行改变..这样OnClickListener就无法进行监听了..
* */
OnClickListener ol=new OnClickListener(){ @Override
public void onClick(View arg0) {
// TODO Auto-generated method stub
if(!((CheckBox)arg0).isChecked()){
Toast.makeText(MainActivity.this,((CheckBox)arg0).getText()+"被取消",Toast.LENGTH_SHORT).show();
}
} };
//起初被点击的时候会直接触发这个监听..当其他复选框被选择的时候这个监听也会被触发..因为可以直接通过OnCheckChangeListener进行直接监听..
OnCheckedChangeListener od=new OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton arg0, boolean arg1) {
// TODO Auto-generated method stub
if(arg1){
Toast.makeText(MainActivity.this,arg0.getText()+"被选择",Toast.LENGTH_SHORT).show();//获取这个对象的资源信息..
}
else{
Toast.makeText(MainActivity.this, arg0.getText()+"被取消", Toast.LENGTH_SHORT).show();
} }
};
CheckBox_1.setOnClickListener(ol);
CheckBox_2.setOnClickListener(ol);
CheckBox_1.setOnCheckedChangeListener(od);
CheckBox_2.setOnCheckedChangeListener(od);
} @Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
} }
v.RadioGroup和RadioButton
这两个代表单选组和单选按钮..这里我们在单选组中加入了两个单选按钮子元素...很简单的东西....
<?xml version="1.0" encoding="utf-8"?>
<linearlayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" > <radiogroup
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical" > <radiobutton
android:id="@+id/radio_red"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="红" >
</radiobutton>
<radiobutton
android:id="@+id/radio_blue"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="蓝" >
</radiobutton> </radiogroup> </linearlayout>
package android.basic.lesson9; import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.RadioButton;
import android.widget.Toast; public class MainHelloRadioGroup extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main); final RadioButton radio_red = (RadioButton) findViewById(R.id.radio_red);
final RadioButton radio_blue = (RadioButton) findViewById(R.id.radio_blue); OnClickListener ocl = new OnClickListener() { @Override
public void onClick(View v) {
Toast.makeText(MainHelloRadioGroup.this, ((RadioButton)v).getText(), Toast.LENGTH_SHORT).show(); }
}; radio_red.setOnClickListener(ocl);
radio_blue.setOnClickListener(ocl);
}
}
这一章内容虽然很多,但是也就是一些基础的东西...主要还是代码多了一些,方便理解..组件这东西多练习练习其实就很容易掌握的...
Android View中的控件和监听方法...的更多相关文章
- EditorGUI控件输入监听
		EditorGUI控件输入监听 在做编辑器开放的过程中,有时候要对用户输入进行判断和限制,但EditorGUI控件却没有触发回调,而是提供了一种麻烦的办法--使用EditorGUI.BeginChan ... 
- Android线程中设置控件
		在Android中经常出现多线程中设置控件的值报错的情况,今天教大家封装一个简单的类避免这样的问题,同样也调用实现也非常的方便. 自定义类: /** * Created by wade on 2016 ... 
- android include中的控件调用
		项目中经常会有一些布局是重用的,但是如何来更好的利用这些布局中的控件 转: http://zhidao.baidu.com/link?url=GU93U8Wu31dfp7mKEx52hMJkxjFLC ... 
- 在win7-64bit环境下,boa-constructor 0.6.1 的palette面板中没有控件图标的解决方法
		在win7-64bit环境下,boa-constructor 0.6.1 的palette面板中没有控件图标,空白一片.将面板窗口拉大,发现那些图标在很下面的位置,X轴的排列与正常状态一致. 软件环境 ... 
- 《转》在win7,boa-constructor 0.6.1 的palette面板中没有控件图标的解决方法
		原地址:http://blog.csdn.net/rickleo/article/details/6532595 在win7-64bit环境下,boa-constructor 0.6.1 的palet ... 
- 母版页改变被嵌套的页面中的控件ID的解决方法
		使用过模板页的朋友都会很纳闷,怎么页面的用js通过getElementById(“id”):找不到对象.查看了页面源代码才发现,原来控件的ID变了,这是母版页导致的.因为母版页怕母版页本身页面中的控件 ... 
- MFC解决View中添加控件闪烁
		一.简介 我们经常会在我们的View类中添加各种类型的控件,列表控件就是最常用的了.但是我们发现添加控件的时候会,在窗口变化的时候会导致各种各样的闪烁,让我们烦恼异常.所以我对此找到新的解决方案. 二 ... 
- Android Studio中Switch控件有关 textOn 和 textOff 用法
		•属性 textOn:控件打开时显示的文字 textOff:控件关闭时显示的文字 showText:设置是否显示开关上的文字(API 21及以上) •用法 <?xml version=" ... 
- Android Studio中Switch控件有关 thumb 和 track 用法
		•任务 •属性 android:track:底部的图片(灰->绿) android:thumb:设置 Switch 上面滑动的滑块,也就是上图中的白色圆形滑块 •switch_thumb 点击 ... 
随机推荐
- Javascript基础恶补
			1.字符集:Javascript采用Unicode字符集,支持地球上所有在用的语言. 2.区分大小写:Javascript区分大小写,HTML不区分大小写. 3.空格.换行.格式控制符:Javascr ... 
- “代理XP”组件已作为此服务器安全配置的一部分被关闭的解决办法
			代理XP”组件已作为此服务器安全配置的一部分被关闭.系统管理员可以使用sp_configure来启用“代理XP”.有关启用“代理XP”的详细信息,请参阅SQL Server联机丛书中的“外围应用配置器 ... 
- StarUml:Exception EOleSysError in module StarUML.ex
			http://sourceforge.net/p/staruml/discussion/510442/thread/9fe12cac/ run as administrator.Works fine. 
- Sicily 3913. 阶乘之和
			http://soj.me/3913 一开始被它的数据吓到了,还以为很复杂,但想清楚之后,确实是比较简单的,你只需要算到 24! 就行了,大于 24 的时候答案永远是 940313,因为我们是对 10 ... 
- 利用Mahout实现在Hadoop上运行K-Means算法
			利用Mahout实现在Hadoop上运行K-Means算法 一.介绍Mahout Mahout是Apache下的开源机器学习软件包,目前实现的机器学习算法主要包含有协同过滤/推荐引擎,聚类和分类三个部 ... 
- 15.6.6-sql字符串组装技巧
			组装sql字符串,丢给exec sp_executesql执行 exec sp_executesql N'exec sp_executesql N''select * from TESTTEST.db ... 
- 利用nodejs+phantomjs+casperjs采集淘宝商品的价格
			因为一些业务需求需要采集淘宝店铺商品的销售价格,但是淘宝详情页面的价格显示是通过js动态调用显示的.所以就没法通过普通的获取页面html然后通过正则或者xpath的方式获取到想到的信息了. 所幸我们现 ... 
- CSS基础(四):盒模型
			CSS盒模型 HTML文档中可以将每个元素都看作是长方形的盒子.而CSS盒模型规定了元素框处理元素内容content.内边距padding.边框border和外边距margin的方式.下图是W3C对于 ... 
- 优酷、YouTube、Twitter及JustinTV视频网站架构设计笔记
			本文是整理的关于优酷.YouTube.Twitter及JustinTV几个视频网站的架构或笔记,对于不管是视频网站.门户网站或者其它的网站,在架构上都有一定的参考意义,毕竟成功者的背后总有值得学习的地 ... 
- 使用 crosswalk-cordova 打包sencha touch 项目,再也不用担心安卓兼容问题!
			国内的安卓手机品牌众多,安卓操作系统碎片化也很严重,我们使用sencha touch 开发的应用不可避免的出现了各种无解的兼容性问题. 有时候我就在想,有没有既能支持cordova,又能让我们把Chr ... 
