Advertisement

Android App 欢迎界面的实现

阅读量:

通过本日的学习活动,我们对App开发的整体流程有了基本的认识.看起来每一个App都具有相当友好的起始界面设计.让我们现在开始设计一个点击操作或者在稍后的时间段内切换到主界面上的起始界面.熟悉一些基本概念和术语是进行后续工作的前提条件

改写说明

这里写图片描述
  • 准备二:建议在res文件夹内创建一个名为"drawable"的子文件夹,并将图文件转移至该子目录中。随后,在src/Package Name目录下新增一个名为"WelcomeActivity"的Android活动(activity)。
  • 准备三:最终按照惯例设计界面,并参考Day 4:五步实现你的第一个Android App一文获取相关指导信息。activity_welcome.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" >
    
    <ImageView
        android:id="@+id/welcomeImage"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentRight="true"
        android:layout_alignParentTop="true"
        android:src="@drawable/asteroids" />
    
    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="124dp"
        android:text="BIG Lottery"
        android:textColor="#FFFFFF"
        android:textSize="48sp"
        android:textStyle="bold|italic" />
    
    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_alignParentRight="true"
        android:layout_marginBottom="45dp"
        android:layout_marginRight="21dp"
        android:text="Hewes17/11/16"
        android:textColor="#FFFFFF"
        android:textSize="18sp"
        android:textStyle="bold|italic中中中中中
     />
    
    </RelativeLayout>

由于项目仅以 MainActivity 作为启动类别的唯一选择,在显示欢迎界面时必须调整 Activity 的启动顺序。为此,请您查看并修改清单文件 AndroidManifest.xml 中的相关代码,并将 MainActivity 中的相关代码进行删除处理:

复制代码
    <intent-filter>
                <action android:name="android.intent.action.MAIN" />
    
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>

即取消了 MainActivity 的启动权限。然而我们最终还是要调动主界面的应用程序的啊,因此我们需要为 Welcome.java 这个类编写相应的代码

(1) 点击跳转
关键步骤:使用 InteractionListener 概念来实现点击监听功能——蚱蜢点击器的概念在此处体现出了重要性

复制代码
    package com.example.biglottery;
    
    import android.app.Activity;
    import android.content.Intent;
    import android.os.Bundle;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.ImageView;
    
    public class Welcome extends Activity {
    	private ImageView welcome;
    
    	@Override
    	protected void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.activity_welcome);
    		
    		welcome=(ImageView)findViewById(R.id.welcomeImage);
    		welcome.setOnClickListener(new OnClickListener(){
    			@Override
    			public void onClick(View arg0) {
    				goMain();				
    			}			
    		});
    	}
    
    	private void goMain() {
    		//设定调动其他的Activity、Service
    		Intent intent=new Intent(this,MainActivity.class);
    		startActivity(intent);	//将控制权交给MainActi`
    ity
    		finish();	//结束
    	}
    
    }

主要步骤包括:首先创建一个新的消息处理对象——new Handler();然后该对象的主要职责是接收并发送相关消息。

复制代码
    package com.example.biglottery;
    
    import android.app.Activity;
    import android.content.Intent;
    import android.os.Bundle;
    import android.os.Handler;
    import android.os.Message;
    
    public class Welcome extends Activity {
    
    	private Handler handler = new Handler() {
        @Override
        public void handleMessage(Message msg) {
        	//接收到消息后跳转
        	goMain();
            super.handleMessage(msg);
        }
    };
    
    	@Override
    	protected void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.activity_welcome);
    			
    		//延迟两秒发送消息
    		handler.sendEmptyMessageDelayed(0,2000);
    	}
    
    	private void goMain() {
    		//设定调动其他的Activity、Service
    		Intent intent=new Intent(this,MainActivity.class);
    		startActivity(intent);	//将控制权交给MainActivity
    		finish();	//结束
    	}
    
    }

效果如下(PS:尺寸问题会在后面统一解决):

这里写图片描述

###开发后
【学习总结】

  • 通过Intent来支持Android各组件间的通信——在Android组件间建立通信渠道时采用Intent来进行界面切换操作;
    • 学习Handler机制——掌握使用android.os.Handler来完成消息延迟发送及相应的处理流程。

【编辑推荐】

全部评论 (0)

还没有任何评论哟~