【Android实验】组件通信Intent
实验目的
了解使用Intent进行组件通信原理
掌握使用Intent启动Activity的方法
熟悉和掌握Android组件间通信的方式和技巧
实验要求
设计一个主Activity和一个子Activity(Sub-Activity),使用主Activity上的按钮启动子Activity,并将子Activity的一些信息返回给主Activity,并显示在主Activity上。
Activity --1.start--> Sub-Activity
Sub-Activity --2.return&show--> Activity
场景解释:
输入当前用户名->确认->输入新的用户名->确认->返回原始界面
请输入当前的用户名 --1.确认--> 请输入新的用户名
请输入新的用户名 --2.输入并确认--> 请输入当前的用户名
请输入新的用户名 --3.返回--> 请输入当前的用户名
实验结果

进入用户主界面

点击登录以后输入新的名字

点击确认以后
实验代码
father.xml:主界面文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<Space
android:layout_width="match_parent"
android:layout_height="150dp" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="欢迎你,"
android:textSize="20dp"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="20dp"
android:text="请输入用户名!"
android:id="@+id/tv_resetName"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="用户名:"
android:textSize="20dp"
/>
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/et_name"
/>
</LinearLayout>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<Space
android:layout_width="120dp"
android:layout_height="match_parent"
android:layout_weight="2"
/>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="登录"
android:textSize="15dp"
android:layout_weight="1"
android:id="@+id/btn_login"
/>
</LinearLayout>
</LinearLayout>
content_child.xml:子界面
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<Space
android:layout_width="match_parent"
android:layout_height="150dp" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="欢迎你,"
android:textSize="20dp"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="20dp"
android:text="请输入用户名!"
android:id="@+id/tv_resetName"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="用户名:"
android:textSize="20dp"
/>
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/et_name"
/>
</LinearLayout>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<Space
android:layout_width="120dp"
android:layout_height="match_parent"
android:layout_weight="2"
/>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="登录"
android:textSize="15dp"
android:layout_weight="1"
android:id="@+id/btn_login"
/>
</LinearLayout>
</LinearLayout>
Fourth.java: 处理文件
package com.example.administrator.fourth;
import android.content.Intent;
import android.net.Uri;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
public class Fourth extends AppCompatActivity {
private static final int SUBACTIVITY1 = 1;
TextView tv_resetName;
Button btn_login;
EditText et_name;
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if(requestCode == SUBACTIVITY1)
{
if(resultCode == RESULT_OK)
{
Uri uriData = data.getData();
tv_resetName.setText(uriData.toString());
}
}
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.father);
tv_resetName = (TextView)findViewById(R.id.tv_resetName);
btn_login = (Button)findViewById(R.id.btn_login);
et_name = (EditText)findViewById(R.id.et_name);
btn_login.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(Fourth.this,ChildActivity.class);
intent.putExtra("Name",et_name.getText().toString());
startActivityForResult(intent,SUBACTIVITY1);
}
});
}
}
ChildActivity.java: 子界面处理文件
package com.example.administrator.fourth;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
public class ChildActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_child);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
final EditText et_resetName = (EditText)findViewById(R.id.et_resetName);
Button btn_sure = (Button)findViewById(R.id.btn_sure);
TextView tv_newUser = (TextView)findViewById(R.id.tv_newUser);
FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
fab.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
.setAction("Action", null).show();
}
});
Intent data = getIntent();
tv_newUser.setText(data.getStringExtra("Name"));
btn_sure.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String uriString = et_resetName.getText().toString();
Uri data = Uri.parse(uriString);
Intent result = new Intent(null,data);
setResult(RESULT_OK,result);
finish();
}
});
}
}
实验总结
通过本次实验,主要是熟悉了Intent的用法,Intent可以看做一封信,用来解决Android应用的各组件之间的通信,他负责对应用中动作,动作涉及的数据,附加数据进行描述,Android则负责根据描述,找到对应的组件,将Intent传递到被调用的组件,并完成组件的调用。
- 父Activity获得子activity分为三步:
在父activity中的按钮监听器中显示启动子activity
Intent intent = new Intent(MainActivity.this,SubActivity.class);
startActivityForResult(intent,SUBACTIVITY1); //SUBACTIVITY1是该activity的静态标志
在子activity调用finish关闭之前调用setResult返回
其中需要返回内容对其进行包装
String uriString = et_resetName.getText().toString();
Uri data = Uri.parse(uriString);
Intent result = new Intent(null,data);
setResult(RESULT_OK,result);
finish();
通用资源标志符(Universal Resource Identifier, 简称"URI")。
Uri代表要操作的数据,Android上可用的每种资源 - 图像、视频片段等都可以用Uri来表示,我们很经常需要解析Uri,并从Uri中获取数据。setResult函数可以设置结果码和返回值,传递给父activity在父activity中写onActivityResult函数获取返回值
if(requestCode == SUBACTIVITY1)
{
if(resultCode == RESULT_OK)
{
Uri uriData = data.getData();
tv_resetName.setText(uriData.toString());
}
}
子activity收到父activity
- 父activity中的处理
Intent intent = new Intent(Fourth.this,ChildActivity.class);
intent.putExtra("Name",et_name.getText().toString());
startActivityForResult(intent,SUBACTIVITY1);
- 子activity中的处理
Intent data = getIntent();
tv_newUser.setText(data.getStringExtra("Name"));
【Android实验】组件通信Intent的更多相关文章
- Android四大组件之Intent
Intent不是android几大组件框架,但是确实是android 各大组件之间沟通的桥梁. 尤其Intent对于activity有很大的关系. 一下是我个人对task以及backstack的总结.
- android三大组件之Intent
Android 应用程序中有三大核心组件: Activity, Service, Broadcast Receiver 都是通过被称之为意图的消息运行. Intent messaging is a f ...
- Android 四大组件和Intent
一.Android有四大组件(component):Activity.Service.BroadcastReceiver.ContentProvider. 1.Activity 通过startActi ...
- Android四大组件之Intent(续2)
1.你如何通过一个intent来唤醒activity? this.startActivity(intent,request); 2.什么是显式.隐式的intents? 显式:指定组件名,通常 ...
- Android四大组件之Intent(续)
- Android应用程序组件之间的通信Intent和IntentFilter
Android应用程序的基本组件,这些基本组建除了Content Provider之外,几乎全部都是依靠Intent对象来激活和通信的. 下面介绍Intent类,并通过例子来说明Intent一般用法 ...
- Intent进行组件通信的一些体会
Intent进行组件通信的原理 l Intent协助应用间的交互与通讯 Intent负责对应用中一次操作的动作.动作涉及数据.附加数据进行描述.Android则根据此Intent的描述,负责找到对应 ...
- android学习日记20--连接组件之Intent和IntentFilter
上次刚了解完Android的四大组件,现在学习组件间通信的Intent和IntentFilter 一.Intent 1.简述 Intent(意图)在应用程序运行时连接两个不同组件,是一种运行时的绑定机 ...
- Android组件系列----Intent详解(转载笔记)
[正文] Intent组件虽然不是四大组件,但却是连接四大组件的桥梁,学习好这个知识,也非常的重要. 一.什么是Intent 1.Intent的概念: Android中提供了Intent机制来协助应用 ...
随机推荐
- SQLServer DBA 三十问
原贴:http://www.cnblogs.com/fygh/archive/2011/10/18/2216166.html 答案:https://blog.csdn.net/cjssimei527/ ...
- CMSPRESS-PHP无限级分类2
原文章地址:http://www.thinkphp.cn/code/170.html 超级无限分类 使用简单 效率极高 核心代码10行不到 另外 求这个分类的不足,和更高效简单的无限分类方法 ^_^ ...
- Selenium+Java元素定位之二
//通过完全匹配链接来定位 driver.findElement(By.linkText("新闻")).click(); //通过部分匹配链接来定位 driver.findElem ...
- [LeetCode] 496. Next Greater Element I_Easy tag: Stack
You are given two arrays (without duplicates) nums1 and nums2 where nums1’s elements are subset of n ...
- 转载一篇debug文章
http://versprite.com/og/ios-reverse-engineering-part-two-debugging-and-tracing-with-lldb/ iOS Revers ...
- css中外边距
1.内部元素设置margin等,父元素高度不能适应 .classA { height: 200px; background-color: cornflowerblue; overflow: hidde ...
- Selenium - Css Selector 使用方法
什么是Css Selector? Css Selector定位实际就是HTML的Css选择器的标签定位 工具 Css Selector可以下载火狐浏览器插件,FireFinder 或 FireBug和 ...
- Docker Quickstart Terminal: exit status 255 解决办法
原文地址:https://www.jianshu.com/p/061f1ae69937 初识docker,还有先拿Windows 7 尝试下,官方提供了docker toolbox,下载后一键安装,桌 ...
- python接口自动化-token参数关联登录(二)
原文地址https://www.cnblogs.com/yoyoketang/p/9098096.html 原文地址https://www.cnblogs.com/yoyoketang/p/68866 ...
- PIMPL(二)
文档下载 上一篇文档,PIMPL(一) 1 如何使用PIMPL 有多种方式实现PIMPL,这里按照<Effective C++>中介绍的方式. 1.1 基本步骤 假设原有Person如下: ...