day06 |
1_今日介绍 |
2_如何创建一个新的Activity&清单文件小细节 | | 重要 |
3_隐式意图 | Templates(自定义模板) |
4_显示意图和隐式意图介绍 |
5_人品计算器案例界面搭建 |
6_人品计算器案例完成 |
7_短信大全实现1 |
8_短信大全案例实现 | intent.putExtra("","") |
9_短信发送器案例1 |
10_发送短信案例完成 | 重要 |
11_Activity的生命周期介绍 | 经典案例透明Activity | 重要 |
12_任务栈的介绍 | 横竖屏切换锁死横竖屏等 | 重要 |
13_Activity的四种启动模式 | 面试长问 | 重要 |
Android中四大组件
activity 广播接收者(broadCastReceiver) 服务(Service) 内容提供者(contentprovider)
四大组件都需要在清单文件里面配置一下
1 如何创建一个新的Activity
(1)如果你想让你的Activity有多个启动图标 需要这样配置
1. <intent-filter>2. <action android:name="android.intent.action.MAIN" />3.4. <category android:name="android.intent.category.LAUNCHER" />5. </intent-filter>
(2)Activity节点下的icon和label 可以和Application节点的icon和label不一样
2 隐式意图
通过指定一组动作或者数据 开启activity
3 显示意图
通过指定具体包名和类名 开启activity
总结
(1)显示意图更加安全一些
(2)开启自己应用的界面用显示意图(不需要配置意图过滤器)
(3)隐式意图一般开启系统应用(电话拨号器 短信的发送器等等)的界面
4 人品计算器小案例
url:资源定位符 www.baidu.com
uri:统一资源标示符 com.itheima.
(1)搭建页面
(2) 写mainActivity的业务逻辑
1.public void click(View v) {2. 3. //[1]获取用户名4. String name = et_name.getText().toString().trim();5. if (TextUtils.isEmpty(name)) {6. Toast.makeText(getApplicationContext(), "用户名不能为空", Toast.LENGTH_LONG).show();7. return;8. }9. 10. //[2]判断选中性别11. int checkedRadioButtonId = rg_group.getCheckedRadioButtonId();12. //[3]判断一下具体选中的性别 13. int sex = 0; //默认值为014. switch (checkedRadioButtonId) {15. case R.id.rb_male: //选中的是男16. sex = 1;17. break;18. 19. case R.id.rb_female: //选中的是女20. sex = 2;21. 22. break;23.24. case R.id.rb_other: //代表选中的是人妖25. sex = 3;26. break;27. }28. //[4]判断性别29. if (sex == 0) {30. Toast.makeText(getApplicationContext(), "亲 请选择性别 ", 0).show();31. return;32. }33.34. //[5] 跳转到resutActivity页面 显示意图35. Intent intent = new Intent(this,ResultActivity.class);36. 37. //[5.1]要把name 和 sex 传递到结果页面 底层map38. intent.putExtra("name", name);39. intent.putExtra("sex", sex);40. 41. //[6]开启Activity42. startActivity(intent);43. 44. 45. 46. }
(3)写resutlActivity的业务逻辑
1.2. super.onCreate(savedInstanceState);3. // 加载页面4. setContentView(R.layout.activity_result);5. // [1]找到我们关心的控件6. TextView tv_name = (TextView) findViewById(R.id.tv_name);7. TextView tv_sex = (TextView) findViewById(R.id.tv_sex);8. TextView tv_result = (TextView) findViewById(R.id.tv_result);9.10. // [2]获取开启此Activity的意图对象11. Intent intent = getIntent();12. // [3]获取我们携带过来的数据 取出性别和name 传递的是什么样的数据类型 你在取的时候13. String name = intent.getStringExtra("name");// 获取name14. int sex = intent.getIntExtra("sex", 0);15.16. // [4]把数据显示到控件上17. tv_name.setText(name); // 显示姓名18.19. // [5]显示性别20. byte[] bytes = null;21. 22. try {23. switch (sex) {24. case 1: // 代表男25. tv_sex.setText("男");26. bytes = name.getBytes("gbk");27. 28. break;29.30. case 2:31. tv_sex.setText("女");32. bytes = name.getBytes("utf-8");33. break;34.35. case 3:36. tv_sex.setText("人妖");37. bytes= name.getBytes("iso-8859-1");38. break;39. }40. } catch (UnsupportedEncodingException e) {41. e.printStackTrace();42. }43.44. //[6]根据我们输入的姓名和性别 来计算人品得分 根据得分显示结果 45. int total = 0;46. for (byte b : bytes) { //0001 100047. int number =b&0xff; //1111 111148. 49. total+=number;50. }51. 52. //算出得分 53. int score = Math.abs(total)%100;54. if (score >90) {55. 56. tv_result.setText("您的人品非常好 您家的祖坟都冒青烟了");57. }else if (score >70) {58. tv_result.setText("有你这样的人品算是不错了..");59. }else if (score >60) {60. tv_result.setText("您的人品刚刚及格");61. }else{62. tv_result.setText("您的人品不及格....");63. 64. }65. 66. 67. 68.
5 短信大全小案例
1. 2. //(1)获取控件 3. ListView lv = (ListView) findViewById(R.id.lv);4. //(2)lv展示数据需要数据适配器 adapter5. ArrayAdapter<String> adapter = new ArrayAdapter<String>(getApplicationContext(), R.layout.item, objects);6. 7. //(3)设置数据适配器 8. lv.setAdapter(adapter);9. //(4)设置条目的监听 10. lv.setOnItemClickListener(new OnItemClickListener() {11.12. //当条目被点击的时候调用13. @Override14. public void onItemClick(AdapterView<?> parent, View view,15. int position, long id) {16. 17. //(5) 获取我们点击条目的数据 小技巧 数据在哪里存着呢 就去哪里去18. String content = objects[position];19. 20. System.out.println("content:"+content);21. 22. //(6)跳转到发送短信页面 用隐式意图 23. /*<intent-filter>24. <action android:name="android.intent.action.SEND" />25. <category android:name="android.intent.category.DEFAULT" />26. <data android:mimeType="text/plain" />27. </intent-filter>*/28. //(7)创建意图对象 29. Intent intent = new Intent();30. intent.setAction("android.intent.action.SEND");31. intent.addCategory("android.intent.category.DEFAULT");32. intent.setType("text/plain");33. 34. //(7.1)把数据传递到 短信的发送页面 35. intent.putExtra("sms_body", content); //要求大家知道这个是怎么来的 ??36. 37. //(8)开启意图 38. startActivity(intent);39. 40. }41. });42. 43. 44. 45. 46. 47. }
6 短信发送器小案例 smsManager
4 5案例有一个共同的特点:A 界面开启B界面 然后把A界面里面的数据传递B界面
A ---->B 当B界面关闭的时候把数据回传给A界面
总结实现步骤
(1)画 mainActivity页面
<LinearLayout 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:orientation="vertical" tools:context=".MainActivity" > <RelativeLayout android:layout_width="match_parent" android:layout_height="wrap_content" > <EditText android:id="@+id/et_number" android:layout_width="match_parent" android:layout_height="wrap_content" android:hint="请输入要发送的号码 " /> <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="click" android:layout_alignParentRight="true" android:layout_alignBottom="@id/et_number" android:text="+" /> </RelativeLayout> <EditText android:id="@+id/et_content" android:layout_width="match_parent" android:layout_height="250dp" android:gravity="top" android:hint="请输入要发送的内容 " /> <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="insert" android:text="插入短信模板" /> <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="send" android:text="发送" /> </LinearLayout> (2) 画联系人页面 用一个listview展示就可以了
(3)写mainActivity的逻辑 主要代码
package com.itheima.smssender; public class MainActivity extends Activity { private EditText et_number; private EditText et_content; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //显示短信发送的内容 et_content = (EditText) findViewById(R.id.et_content); //显示号码 et_number = (EditText) findViewById(R.id.et_number); } //点击按钮 跳转到联系人页面 public void click(View v){ //创建一个意图对象 跳转联系人页面 Intent intent = new Intent(this,ContactActivity.class); //如果你调用这个方法 就是简单开启页面 不能拿到返回的数据 注意:如果你想开启一个activity 并且想要获取开启的这个activity返回的数据 要调用这个方法 startActivityForResult(intent, 1);// startActivity(intent); } //点击按钮 实现发送短信短信的逻辑 public void send(View v){ //TODO 一会实现 } //点击按钮 打开插入短信模板 页面 public void insert(View v){ Intent intent = new Intent(this,SmsTemplateActivity.class); startActivityForResult(intent, 2); } //当这个activity(MainActivity) 开启联系人页面时 当联系人页面关闭的时候这个方法会调用 @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { System.out.println("onActivityResult"); /*if (resultCode == 10) { //代表这个数据 是从联系人页面获取的 //(1)取出我们在联系人页面设置的数据 String phone = data.getStringExtra("phone"); et_number.setText(phone); }else if (resultCode == 20) { //(2)把短信模板页面的数据显示到et_content控件上 String smscontent = data.getStringExtra("smscontent"); et_content.setText(smscontent); } */ if (requestCode == 1) { //代表请求联系人页面 //(1)取出我们在联系人页面设置的数据 String phone = data.getStringExtra("phone"); et_number.setText(phone); }else if(requestCode == 2){ //请求短信模板页面 //(2)把短信模板页面的数据显示到et_content控件上 String smscontent = data.getStringExtra("smscontent"); et_content.setText(smscontent); } super.onActivityResult(requestCode, resultCode, data); } }(4)写短信模板页面 也是用一个listview展示即可
(5)短信模板页面主要代码 如下
package com.itheima.smssender; public class SmsTemplateActivity extends Activity { String objects[] = {"我在开会,请稍后在打...","我在吃饭,请稍后在打...","我在打酱油,请稍后在打...","我在约会,请稍后在打...","我在打麻将,请稍后在打..."}; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); //加载这个布局 setContentView(R.layout.activity_smstemplate); //(1)找到listview ListView lv = (ListView) findViewById(R.id.lv); //(2)把我们定义的好数据显示到listview上 lv.setAdapter(new ArrayAdapter<String>(getApplicationContext(), R.layout.smstemlpate_item, objects)); //(3)给listview设置点击事件 lv.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { //(4)取出点击条目的数据 String smscontent = objects[position]; //(5)当页面关闭的时候把数据返回 Intent intent = new Intent(); intent.putExtra("smscontent", smscontent); //(6)把数据返回给调用者 setResult(20, intent); //(7)关闭这个Activity finish(); } }); }}
(6)实现发送短信的功能
//(2)实现发送短信的功能 smsManager 获取这个类的实例 SmsManager smsManager = SmsManager.getDefault(); //(3)分割短信 分条发送 ArrayList<String> divideMessages = smsManager.divideMessage(content); for (String div : divideMessages) { //(4)发送短信 smsManager.sendTextMessage(number, null, div, null, null); }(7)记得要加上发送短信的权限
android.permission.SEND_SMS
7 Activity的生命周期 (必须掌握)
oncreate 方法 当Activity第一次启动的时候调用
onDestroy 方法 当Activity销毁的时候调用
onStrat() 方法 当Activity变成可见的时候调用
onStop() 方法 当activity 不可见的时候调用
onResume()方法 当activity可以获取焦点的时候 当界面的按钮可以被点击了
onPause()方法 当失去焦点的时候调用 当按钮不了可以被点击的时候调用
onRestart()当界面重新启动的时候调用
8 横竖屏切换Activity的生命周期
(1)为了防止横竖屏切换 生命周期会发生变化 所以把Activity配置如下
android:screenOrientation="portrait"
(2)为了声明周期不变化
android:configChanges="orientation|keyboardHidden|screenSize"
9 任务栈的概念
栈:先进后出
队列:先进先出
Task 打开一个Activity叫进栈 关闭一个activit出栈
任务栈是用来维护Activity的 是用来维护用户的操作体验
我们操作的Activity永远是任务栈的栈顶的Activity
说应用程序退出了 实际上任务栈清空了
10 Activity的四种启动模式
##12_singletop启动模式
1. singletop 单一顶部模式 在activity的配置文件中设置android:launchMode="singleTop"
如果任务栈的栈顶存在这个要开启的activity,不会重新的创建activity,而是复用已经存在的activity。保证栈顶如果存在,不会重复创建。
应用场景:浏览器的书签
##13_singletask和singleinstance启动模式
singetask 单一任务栈,在当前任务栈里面只能有一个实例存在
当开启activity的时候,就去检查在任务栈里面是否有实例已经存在,如果有实例存在就复用这个已经存在的activity,并且把这个activity上面的所有的别的activity都清空,复用这个已经存在的activity。保证整个任务栈里面只有一个实例存在
应用场景:浏览器的activity
如果一个activity的创建需要占用大量的系统资源(cpu,内存)一般配置这个activity为singletask的启动模式。
singleInstance启动模式非常特殊, activity会运行在自己的任务栈里面,并且这个任务栈里面只有一个实例存在
如果你要保证一个activity在整个手机操作系统里面只有一个实例存在,使用singleInstance
应用场景: 来电页面