android学习四---Activity和Intent

时间:2022-01-28 15:33:16

1.android项目资源深入了解

      在深入学习android之前,先好好玩玩手机上的应用,大部分程序都有一个图标,点开图标,程序启动,一定时间后,程序会跳转到第一个界面,比如手机QQ,点开图标,会跳出一幅图,接着就跳到QQ登陆的界面(如下图)。这个界面里有输入框输入QQ号码,密码,有个登陆按钮,有记住密码选择框,还有一些图标和文本。如果你输入了密码和账号后,点击登陆,程序就会响应。发送到服务器端会检查账号,密码。账号密码一致的话就会就会跳到用户界面。

android学习四---Activity和Intent

     假设需要实现这样的一个界面,对应的android项目里需要哪些资源呢。首先需要在res资源文件夹中的drawable里放置一张初始显示的图片,value里的string里放置各种button上显示的字符串资源。然后登陆界面就是一个activity,这个activity上能够对各种按钮,文本框进行响应或者跳转到另一个activity,这个监听或者响应的代码就在src的java源代码里定义。而这个界面的布局文件在xml文件里。添加了一个资源,在gen里的R.java会自动生成索引。

2.一个简单的android项目

2.1 效果

   点击activity1中的send会跳转到Activity2,然后点击back就会回到activity1。

android学习四---Activity和Intent android学习四---Activity和Intent

2.2 构思

    首先要构建两个界面,每个界面是activity,我们定义界面一的activity为activity1,定义界面二的activity为Activity2.分别为界面一二创建布局。程序中主要是解决两个问题,(1)如何知道按键被按下了(2)两个activity之间如何进行通信。

对于第一个问题,先要取得布局中的button对象,然后调用对象的setOnClickListener 进行监听,当监听的事件发生后(按下按键),就执行onClick方法。

对于第二个问题,需要采用android的一个类Intent来实现,Intent顾名思义意图即程序想要表达的意图,这个意图怎么表达的呢?需要实施的动作和具体的数据。这里的Intent的作用主要是协助完成android各个组件之间的通讯。比如说调用startActivity()来启动一个activity,或者由broadcaseIntent()来传递给所有感兴趣的BroadcaseReceiver, 再或者由startService()/bindservice()来启动一个后台的service。

2.3 实现

    先新建一个blank activity,在生成的.xml文件里定义一个button。

<RelativeLayout 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:paddingBottom
="@dimen/activity_vertical_margin"
android:paddingLeft
="@dimen/activity_horizontal_margin"
android:paddingRight
="@dimen/activity_horizontal_margin"
android:paddingTop
="@dimen/activity_vertical_margin"
tools:context
="com.example.activitiy1.MainActivity" >

<Button
android:id
="@+id/buttonsend"
android:layout_width
="wrap_content"
android:layout_height
="wrap_content"
android:text
="@string/button_send"
android:onClick
="sendMessage"/>
</RelativeLayout>

android:id="@+id/buttonsend" 代表Button的id ,第一次添加资源时需要加+号,名字可以随意取,最好取有意义的好东岸。

android:layout_width:定义当前视图在屏幕上所占的宽度, fill_parent/ match_parent 即填充整个屏幕。 
android:layout_height:定义当前视图在屏幕上所占的高度, fill_parent/ match_parent 即填充整个屏幕。

wrap_content:随着文字大小的不同而改变这个视图的宽度或高度。

android:text="@string/button_send":引用的是string里的字符串,这里的字符串都需要在values里的String.xml中进行定义。

定义方式为<string name="button_send">send</string>。两个<><>间的字符串即为在界面中显示的,支持中文。

同样点击new –other,创建一个Activity2

android学习四---Activity和Intent

android学习四---Activity和Intent

   填写Activity Name 和Layout Name,本项目中采用的名字分别是Activity2和main_activity2。

同样创建界面main_activity2.xml代码

<RelativeLayout 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:paddingBottom
="@dimen/activity_vertical_margin"
android:paddingLeft
="@dimen/activity_horizontal_margin"
android:paddingRight
="@dimen/activity_horizontal_margin"
android:paddingTop
="@dimen/activity_vertical_margin"
tools:context
="com.example.activitiy1.Activity2" >

<Button
android:id
="@+id/buttonback"
android:layout_width
="wrap_content"
android:layout_height
="wrap_content"
android:text
="@string/button_back"
android:onClick
="sendMessage"/>

</RelativeLayout>

    界面都弄好之后,就需要在src源代码里实现相应功能。主要是在Oncreate的时候,监听按键,按键按下时,新建一个Intent,然后利用这个Intent来启动另一个activity。

MainActivity.java和Activity2的代码如下

package com.example.activitiy1;

import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;

public class MainActivity extends ActionBarActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button button
=(Button) findViewById(R.id.buttonsend);
button.setOnClickListener(
new Button.OnClickListener(){
public void onClick(View v){
Intent intent
=new Intent();
intent.setClass(MainActivity.
this, Activity2.class);
startActivity(intent);
MainActivity.
this.finish();
}
});
}

@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;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}

Activity2

package com.example.activitiy1;

import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;

public class Activity2 extends ActionBarActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main_activity2);
Button button
=(Button) findViewById(R.id.buttonback);
button.setOnClickListener(
new Button.OnClickListener(){
public void onClick(View v){
Intent intent
=new Intent();
intent.setClass(Activity2.
this, MainActivity.class);
startActivity(intent);
Activity2.
this.finish();
}
});
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.activity2, menu);
return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.activitiy1"
android:versionCode
="1"
android:versionName
="1.0" >

<uses-sdk
android:minSdkVersion
="8"
android:targetSdkVersion
="21" />

<application
android:allowBackup
="true"
android:icon
="@drawable/ic_launcher"
android:label
="@string/app_name"
android:theme
="@style/AppTheme" >
<activity
android:name
=".MainActivity"
android:label
="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name
=".Activity2"
android:label
="@string/title_activity_activity2" >
</activity>
</application>

</manifest>