• android学习四---Activity和Intent


    1.android项目资源深入了解

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

    153144546875

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

    2.一个简单的android项目

    2.1 效果

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

    image image

    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

    image

    image

    填写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>
  • 相关阅读:
    .net测试篇之Moq行为配置
    .net测试篇之Moq框架简单使用
    .net测试篇之测试神器Autofixture在几个复杂场景下的使用示例以及与Moq结合
    .net测试篇之测试神器Autofixture Generator使用与自定义builder
    .net测试篇之测试神器Autofixture基本配置一
    .net测试篇之单元测试/集成测试神器Autofixture
    .netcore持续集成测试篇之web项目验收测试
    .netcore持续集成测试篇之 .net core 2.1项目集成测试
    .netcore持续集成测试篇之MVC层单元测试
    .netcore持续集成测试篇之测试方法改造
  • 原文地址:https://www.cnblogs.com/dawnminghuang/p/4132134.html
Copyright © 2020-2023  润新知