首页 > 代码库 > android学习四---Activity和Intent
android学习四---Activity和Intent
1.android项目资源深入了解
在深入学习android之前,先好好玩玩手机上的应用,大部分程序都有一个图标,点开图标,程序启动,一定时间后,程序会跳转到第一个界面,比如手机QQ,点开图标,会跳出一幅图,接着就跳到QQ登陆的界面(如下图)。这个界面里有输入框输入QQ号码,密码,有个登陆按钮,有记住密码选择框,还有一些图标和文本。如果你输入了密码和账号后,点击登陆,程序就会响应。发送到服务器端会检查账号,密码。账号密码一致的话就会就会跳到用户界面。
假设需要实现这样的一个界面,对应的android项目里需要哪些资源呢。首先需要在res资源文件夹中的drawable里放置一张初始显示的图片,value里的string里放置各种button上显示的字符串资源。然后登陆界面就是一个activity,这个activity上能够对各种按钮,文本框进行响应或者跳转到另一个activity,这个监听或者响应的代码就在src的java源代码里定义。而这个界面的布局文件在xml文件里。添加了一个资源,在gen里的R.java会自动生成索引。
2.一个简单的android项目
2.1 效果
点击activity1中的send会跳转到Activity2,然后点击back就会回到activity1。
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
填写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>
android学习四---Activity和Intent