上一节,写了一个简单的APP,不过它只是单个界面的。
在企业级应用产品开发中,通常一个APP都是由多个复杂的页面来构成的。我们将它适当性的扩展为两个界面,其中第一个界面是这样的:
通过按键点击就会跳转到另外一个页面,如下:
如何来实现呢?在此先来了解下啥叫Activity?啥叫Intent?
Activity是Android的四大组件之一,是一个用来与用户交互的组件。比如我们的屏幕画面,上面提供了按钮等可以操作的控件,用户利用这些控件来达到某种目的。这就是一个Activity了。
Intent就是Activity与Activity进行通信的一个桥梁,一个APP有很多个页面,切换这些页面就需要Activity,比如我开发了两个画面,一个叫Main,一个叫Setting,即Main页面就存在一个MainActivity,用来管理Main页面相关的操作和其它。Setting页面就存在一个SettingActivity,用来管理Setting页面相关的操作和其它。
详情可以去找一本Android app的书看一看,了解一下,这里就不介绍那么多的理论知识。
1、实现方法
1.1 新建一个Activity
在弹出的方框中选择Android===>Android Activity
默认选择next
创建一个新的Activity,通常选择Blank Activity就可以了,然后填写新的Activity相关的信息,由于下面已经有一个SettingActivity,所以无法选择Finish,这是我之前已经创建好的了,这里演示一下过程,直接点Finish就完成了。(正常流程)
创建Activity完成后,ADT集成开发环境就会把相关的文件添加到各个文件夹中去,比如布局layout,就会生成一个新的页面的布局,在AndroidManifest.xml中,注册新建的Activity,这样就能实现两个Activity之间的交互了。
AndroidManifest.xml如下:
<uses-sdk android:minSdkVersion="14" android:targetSdkVersion="18" /> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <activity android:name="com.example.network_tool.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="com.example.network_tool.SettingActivity" android:label="@string/title_activity_setting" > </activity> </application>
1.2 两个Activity界面切换逻辑布局(MainActivity与SettingActivity)
1.2.1 先来看看主页面的布局文件。
<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=".MainActivity" > <TextView android:id="@+id/wifi_addr" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_alignParentRight="true" android:text="@string/_wifi_" /> <Button android:id="@+id/Return_button" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignRight="@+id/wifi_addr" android:layout_below="@+id/wifi_addr" android:layout_marginTop="44dp" android:text="@string/Setting" /> </RelativeLayout>
1.2.2 以下是设置页面的布局,红框中有TextView控件
<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=".SettingActivity" > <Button android:id="@+id/Connect" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_alignParentRight="true" android:layout_alignParentTop="true" android:layout_marginTop="44dp" android:text="@string/Connect" /> <TextView android:id="@+id/wifi_addr" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignLeft="@+id/Connect" android:layout_alignParentRight="true" android:layout_below="@+id/Connect" android:layout_marginTop="41dp" android:text="" /> <TextView android:id="@+id/wifi_mask" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:layout_below="@+id/wifi_addr" android:layout_marginTop="30dp" android:text="" /> <TextView android:id="@+id/wifi_gateway" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignLeft="@+id/wifi_mask" android:layout_alignParentRight="true" android:layout_below="@+id/wifi_mask" android:layout_marginTop="39dp" android:text="" /> <TextView android:id="@+id/wifi_server_ip" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:layout_below="@+id/wifi_gateway" android:layout_marginTop="34dp" android:text="" /> <TextView android:id="@+id/wifi_dns1" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignLeft="@+id/wifi_server_ip" android:layout_alignParentRight="true" android:layout_centerVertical="true" android:text="" /> <TextView android:id="@+id/wifi_dns2" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignRight="@+id/wifi_dns1" android:layout_below="@+id/wifi_dns1" android:layout_marginTop="34dp" android:text="" /> <Button android:id="@+id/Return" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignLeft="@+id/wifi_dns2" android:layout_alignParentBottom="true" android:layout_alignParentRight="true" android:layout_marginBottom="55dp" android:text="@string/Return" /> </RelativeLayout>
1.3 两个Activity界面切换代码逻辑编写(MainActivity与SettingActivity)
1.3.1 主页面的代码逻辑:
package com.example.network_tool; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.Menu; import android.view.View; import android.widget.Button; public class MainActivity extends Activity implements View.OnClickListener{ private Button Setting ; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Setting = (Button)findViewById(R.id.Return_button); //设置按钮监听 Setting.setOnClickListener(this); } @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 void onClick(View arg0) { // TODO Auto-generated method stub switch(arg0.getId()) { case R.id.Return_button: //通过Intent从MainActivity切换到SettingActivity Intent intent = new Intent(); intent.setClass(MainActivity.this, SettingActivity.class); startActivity(intent); break ; default: break ; } } }
1.3.2 设置页面的代码逻辑:
package com.example.network_tool; import android.app.Activity; import android.content.Intent; import android.net.DhcpInfo; import android.net.wifi.WifiManager; import android.os.Bundle; import android.view.Menu; import android.view.View; import android.widget.Button; import android.widget.TextView; public class SettingActivity extends Activity implements View.OnClickListener { private Button Return_Button , Connect_Button; private WifiManager __WifiManager; private DhcpInfo __DhcpInfo; private TextView wifi_addr,wifi_mask,wifi_gateway,wifi_dns1,wifi_dns2,wifi_server ; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_setting); //找控件ID Connect_Button = (Button)findViewById(R.id.Connect); Return_Button = (Button)findViewById(R.id.Return); wifi_addr = (TextView)findViewById(R.id.wifi_addr); wifi_mask = (TextView)findViewById(R.id.wifi_mask); wifi_gateway = (TextView)findViewById(R.id.wifi_gateway); wifi_server = (TextView)findViewById(R.id.wifi_server_ip); wifi_dns1 = (TextView)findViewById(R.id.wifi_dns1); wifi_dns2 = (TextView)findViewById(R.id.wifi_dns2); //获取系统服务==>wifi __WifiManager = ((WifiManager) getSystemService("wifi")); //获取动态节点信息 __DhcpInfo = __WifiManager.getDhcpInfo(); //设置按钮监听 Connect_Button.setOnClickListener(this); Return_Button.setOnClickListener(this); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.setting, menu); return true; } @Override public void onClick(View arg0) { // TODO Auto-generated method stub switch(arg0.getId()) { case R.id.Connect: wifi_addr.setText("IP地址:" + intToIp(__DhcpInfo.ipAddress)); wifi_mask.setText("掩码:" + intToIp(__DhcpInfo.netmask)); wifi_gateway.setText("网关:" + intToIp(__DhcpInfo.gateway)); wifi_server.setText("服务器:" + intToIp(__DhcpInfo.serverAddress)); wifi_dns1.setText("DNS1:" + intToIp(__DhcpInfo.dns1)); wifi_dns2.setText("DNS2:" + intToIp(__DhcpInfo.dns2)); break ; case R.id.Return: //从设置页面返回主页面 Intent intent = new Intent(); intent.setClass(SettingActivity.this, MainActivity.class); startActivity(intent); break ; default: break ; } } //转换地址 private String intToIp(int paramInt) { return (paramInt & 0xFF) + "." + (0xFF & paramInt >> 8) + "." + (0xFF & paramInt >> 16) + "." + (0xFF & paramInt >> 24); } }
1.4 设置用户权限
在AndroidManifest.xml中已添加。
<uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
1.5 连接手机,运行apk到手机上
略。
1.6 运行结果
先连接wifi热点,打开app后,点击设置,会切换到设置页面,然后点击连接,会弹出上一节的内容,点击返回会退回到主页面。