安卓四大核心组件之Activity

2024-09-04 08:08

本文主要是介绍安卓四大核心组件之Activity,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安卓四大核心组件指的是Activity、Service、BroadcastReceiver、ContentProvider。下面总结一下Activity中一些常用控件的用法。

主要有以下5个方面:

Part A:TextView和EditText的使用

Part B:ImageView的使用

Part C:ToggleButton(开关按钮)、RadioButton(单选按钮)和CheckBox(复选按钮)的使用

PartD:DatePicker和TimePicker的使用

PartE: ListView的使用


Part A:TextView和EditView的使用

图一

TextView(文本框)是Android系统中最常见的控件之一,使用TextView可生成一段文本文字,合理使用TextView的属性还能使文字变得有资有色。TextView还可以用来显示超链接、走马灯效果…

TextView控件可以通过XML文件设置全部属性,也可以通过java代码设置属性。

XML文件:

<TextView android:layout_width="wrap_content"android:layout_height="wrap_content"android:id="@+id/text"android:text="@string/back"android:textColor="#00ff00"android:textSize="20sp"/>
Java代码:

//获取TextView组件
TextView text = (TextView)findViewById(R.id.text);
//网页标签,这里一定要加http
String label = "<html><a href='http://www.baidu.com'>百度</a></html>";
//调用set方法设置属性
text.setTextSize(30);//设置文本的字体大小为30dp
text.setText(Html.fromHtml(label));//将网页标签显示出来
//设置移动方法,即超链接的跳转效果
text.setMovementMethod(LinkMovementMethod.getInstance());
EditText是Android系统中的编辑框,可以理解为可编辑的TextView,由图一亦可知EditText实为TextView的直接子类,故它的用法和属性设置与TextView很相似。但EditText的用途却比TextView多很多。以下是笔者的一些小总结:

XML文件:

<EditText android:layout_width="match_parent"android:layout_height="wrap_content"android:id="@+id/edit"/><Button android:layout_width="wrap_content"android:layout_height="wrap_content"android:id="@+id/button"/>
Java代码:

EditText edit = (EditText)findViewById(R.id.edit);
//1.用于提示信息
String content = edit.getText().toString();
if(content == null||content.equals("")){
edit.setError("输入不能为空!!!");
}
2. 对要编辑的内容进行限定,如果没有 digits inputType numeric 这些限定,则默认为什么内容都能输入(数字、字母、符号)

XML文件:

<EditText android:layout_width="match_parent"android:layout_height="wrap_content"android:digits="abczf"/><EditText android:layout_width="match_parent"android:layout_height="wrap_content"android:inputType="textCapCharacters|number"/><EditText android:layout_width="match_parent"android:layout_height="wrap_content"android:numeric="decimal|signed"/>
Part B:ImageView的使用

很多时候我们不想把东西都放在APK里面,或者是不能放进去,这时候我们就需要万能的网络帮助自己实现。

Java代码:

package com.example.test_widget;import java.io.ByteArrayOutputStream;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.LinearLayout;
/*** ImageViewTest  从网络获取资源* @author 赵芳* 2014-7-18* 下午5:04:24*/
public class ImageViewTest extends Activity{protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);LinearLayout layout = new LinearLayout(this);Button btn = new Button(this);btn.setText("从网络获取图片");final ImageView image = new ImageView(this);layout.addView(btn);layout.addView(image);setContentView(layout);btn.setOnClickListener(new OnClickListener() {public void onClick(View v) {new Thread(){public void run() {try {//1.根据流对象获取网络资源(1和2选其一)InputStream in = getImageFromNet1("http:// 192.168.0.15:8080/test/test.jpg");final Bitmap bmp = BitmapFactory.decodeStream(in);//2.根据数组获取流对象
//							byte[] by = getImageFromNet("http://192.168.0.15:8080/test/test.jpg");
//							final Bitmap bmp = BitmapFactory.decodeByteArray(by, 0, by.length);image.post(new Runnable() {public void run() {image.setImageBitmap(bmp);}});} catch (Exception e) {e.printStackTrace();}}}.start();}});}/*** 从指定的url上获取资源* @param path 指定的url* @return 流对象*/public InputStream getImageFromNet1(String path){InputStream in = null;try {URL url = new URL(path);HttpURLConnection  conn =  (HttpURLConnection)url.openConnection();in = conn.getInputStream();} catch (Exception e) {e.printStackTrace();}return in;}/*** 根据路径path从网络上获取图片* @param path* @return 字节数组对象* @throws MalformedURLException */public byte[] getImageFromNet(String path) throws Exception{URL url = new URL(path);HttpURLConnection conn = (HttpURLConnection) url.openConnection();InputStream in = conn.getInputStream();byte[] by = new byte[1024];ByteArrayOutputStream baos = new ByteArrayOutputStream();int len = -1;while((len = in.read(by)) != -1){baos.write(by, 0, len);}return  baos.toByteArray();}
} 
Part C:ToggleButton(开关按钮)、RadioButton(单选按钮)和CheckBox(复选按钮)的使用

参考链接:http://www.cnblogs.com/plokmju/archive/2013/07/22/android_UI_CompoundButton.html

PartD:DatePicker和TimePicker的使用

Toggle.xml文件:
<DatePickerandroid:id="@+id/date"android:layout_width="wrap_content"android:layout_height="wrap_content" android:layout_gravity="center_horizontal"/><TimePickerandroid:id="@+id/time"android:layout_width="wrap_content"android:layout_height="wrap_content" android:layout_gravity="center_horizontal" />
java代码:
package com.example.test_widget;import java.util.Calendar;import android.app.Activity;
import android.os.Bundle;
import android.widget.DatePicker;
import android.widget.DatePicker.OnDateChangedListener;
import android.widget.TimePicker;
import android.widget.TimePicker.OnTimeChangedListener;
/*** 设置时间日期* @author * 2014-7-20* 下午6:10:12*/
public class DataPickerTest extends Activity {private DatePicker date;private TimePicker time;private int year,month,day,hour,min;protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.toggle);date = (DatePicker)findViewById(R.id.date);date.setCalendarViewShown(false);//若版本较低,此处会报错time = (TimePicker)findViewById(R.id.time);time.setIs24HourView(true);//設置24小時制Calendar c = Calendar.getInstance();year = c.get(Calendar.YEAR);month = c.get(Calendar.MONTH);day = c.get(Calendar.DAY_OF_MONTH);hour = c.get(Calendar.HOUR_OF_DAY);min = c.get(Calendar.MINUTE);//监听date、timedate.init(year, month, day, new OnDateChangedListener() {public void onDateChanged(DatePicker view, int year, int monthOfYear,int dayOfMonth) {//將改变的時间显示到activity标题上DataPickerTest.this.year = year;month = monthOfYear + 1;day = dayOfMonth;setTitle(DataPickerTest.this.year+"-"+month+"-"+day+" "+hour+":"+min);}});time.setOnTimeChangedListener(new OnTimeChangedListener() {public void onTimeChanged(TimePicker view, int hourOfDay, int minute) {hour = hourOfDay;min = minute;}});}
}

PartE: ListView的使用

在Android开发中,ListView是比较常用的控件,它以列表的形式显示具体内容,并且能够根据数据的长度自适应显示。 在ListView中可以根据需要显示自定义的列表内容,包括文字(TextView)、图片(ImageView)、按钮(Button)等,以此构成图文并茂的显示效果。

Java代码:

package com.example.test_widget;import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.AdapterView.OnItemLongClickListener;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.TextView;
import android.widget.Toast;/*** listview测试类,布局文件限制条目的改变( 数据源----->适配器------>界面)* 主要布局文件:list.xml    另外还有个适配器的关联文件:list_item.xml* @author 赵芳 2014-7-20 下午9:28:52*/
public class ListViewTest extends Activity {private ListView list;protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.list);list = (ListView) findViewById(R.id.list);// 关联数据源final List<Map<String, Object>> dataList = new ArrayList<Map<String, Object>>();// 模拟数据源for (int i = 0; i < 10; i++) {Map<String, Object> map = new HashMap<String, Object>();map.put("title", "title" + i);map.put("content", "content" + i);map.put("image", R.drawable.face2);dataList.add(map);}// 构建适配器SimpleAdapter adapter = new SimpleAdapter(this, dataList,R.layout.list_item,new String[] { "title", "content", "image" }, new int[] {R.id.title, R.id.content, R.id.image });list.setAdapter(adapter);// 监听list中每个条目被点击list.setOnItemClickListener(new OnItemClickListener() {public void onItemClick(AdapterView<?> parent, View view,int position, long id) {// 获取选中条目的title
//				setTitle((String)dataList.get(position).get("title"));TextView content = (TextView)view.findViewById(R.id.content);setTitle(content.getText());}});// 监听list中每个条目被长时间点击list.setOnItemLongClickListener(new OnItemLongClickListener() {public boolean onItemLongClick(AdapterView<?> parent, View view,int position, long id) {Toast.makeText(ListViewTest.this, "你选择了第" + position + "条目", 3).show();return false;}});}
}

List.xml文件:

<?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" ><ListView android:id="@+id/list" android:layout_width="match_parent" android:layout_height="wrap_content"/>
</LinearLayout>
List_item.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical" ><TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="10sp" android:layout_marginLeft="10sp" android:id="@+id/title" /> <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentRight="true"android:layout_marginRight="20sp" android:layout_marginTop="20sp" android:id="@+id/image" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="10sp" android:layout_below="@id/title" android:id="@+id/content" /></RelativeLayout>

更多参考链接:http://www.cnblogs.com/menlsh/archive/2013/03/15/2962350.html












这篇关于安卓四大核心组件之Activity的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1135467

相关文章

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

基于Qt Qml实现时间轴组件

《基于QtQml实现时间轴组件》时间轴组件是现代用户界面中常见的元素,用于按时间顺序展示事件,本文主要为大家详细介绍了如何使用Qml实现一个简单的时间轴组件,需要的可以参考下... 目录写在前面效果图组件概述实现细节1. 组件结构2. 属性定义3. 数据模型4. 事件项的添加和排序5. 事件项的渲染如何使用

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

vue2 组件通信

props + emits props:用于接收父组件传递给子组件的数据。可以定义期望从父组件接收的数据结构和类型。‘子组件不可更改该数据’emits:用于定义组件可以向父组件发出的事件。这允许父组件监听子组件的事件并作出响应。(比如数据更新) props检查属性 属性名类型描述默认值typeFunction指定 prop 应该是什么类型,如 String, Number, Boolean,

kubelet组件的启动流程源码分析

概述 摘要: 本文将总结kubelet的作用以及原理,在有一定基础认识的前提下,通过阅读kubelet源码,对kubelet组件的启动流程进行分析。 正文 kubelet的作用 这里对kubelet的作用做一个简单总结。 节点管理 节点的注册 节点状态更新 容器管理(pod生命周期管理) 监听apiserver的容器事件 容器的创建、删除(CRI) 容器的网络的创建与删除

消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法

消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法   消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法 [转载]原地址:http://blog.csdn.net/x605940745/article/details/17911115 消除SDK更新时的“