Android获取已连接wifi的热点信息(上位机开发学习之多个界面切换编程)

简介: Android获取已连接wifi的热点信息(上位机开发学习之多个界面切换编程)

上一节,写了一个简单的APP,不过它只是单个界面的。

在企业级应用产品开发中,通常一个APP都是由多个复杂的页面来构成的。我们将它适当性的扩展为两个界面,其中第一个界面是这样的:

640.png

通过按键点击就会跳转到另外一个页面,如下:

640.png

   如何来实现呢?在此先来了解下啥叫Activity?啥叫Intent?

   Activity是Android的四大组件之一,是一个用来与用户交互的组件。比如我们的屏幕画面,上面提供了按钮等可以操作的控件,用户利用这些控件来达到某种目的。这就是一个Activity了。

   Intent就是Activity与Activity进行通信的一个桥梁,一个APP有很多个页面,切换这些页面就需要Activity,比如我开发了两个画面,一个叫Main,一个叫Setting,即Main页面就存在一个MainActivity,用来管理Main页面相关的操作和其它。Setting页面就存在一个SettingActivity,用来管理Setting页面相关的操作和其它。

   详情可以去找一本Android app的书看一看,了解一下,这里就不介绍那么多的理论知识。

1、实现方法

1.1 新建一个Activity

640.jpg

在弹出的方框中选择Android===>Android Activity

640.jpg

默认选择next

640.jpg

   创建一个新的Activity,通常选择Blank Activity就可以了,然后填写新的Activity相关的信息,由于下面已经有一个SettingActivity,所以无法选择Finish,这是我之前已经创建好的了,这里演示一下过程,直接点Finish就完成了。(正常流程)

640.jpg

创建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 先来看看主页面的布局文件。

640.png

<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控件

640.png

<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后,点击设置,会切换到设置页面,然后点击连接,会弹出上一节的内容,点击返回会退回到主页面。

640.jpg

目录
相关文章
|
2月前
|
Android开发 数据安全/隐私保护 开发者
Android自定义view之模仿登录界面文本输入框(华为云APP)
本文介绍了一款自定义输入框的实现,包含静态效果、hint值浮动动画及功能扩展。通过组合多个控件完成界面布局,使用TranslateAnimation与AlphaAnimation实现hint文字上下浮动效果,支持密码加密解密显示、去除键盘回车空格输入、光标定位等功能。代码基于Android平台,提供完整源码与attrs配置,方便复用与定制。希望对开发者有所帮助。
|
2月前
|
XML Java Android开发
Android自定义view之网易云推荐歌单界面
本文详细介绍了如何通过自定义View实现网易云音乐推荐歌单界面的效果。首先,作者自定义了一个圆角图片控件`MellowImageView`,用于绘制圆角矩形图片。接着,通过将布局放入`HorizontalScrollView`中,实现了左右滑动功能,并使用`ViewFlipper`添加图片切换动画效果。文章提供了完整的代码示例,包括XML布局、动画文件和Java代码,最终展示了实现效果。此教程适合想了解自定义View和动画效果的开发者。
152 65
Android自定义view之网易云推荐歌单界面
|
1月前
|
安全 Java Android开发
为什么大厂要求安卓开发者掌握Kotlin和Jetpack?深度解析现代Android开发生态优雅草卓伊凡
为什么大厂要求安卓开发者掌握Kotlin和Jetpack?深度解析现代Android开发生态优雅草卓伊凡
73 0
为什么大厂要求安卓开发者掌握Kotlin和Jetpack?深度解析现代Android开发生态优雅草卓伊凡
|
2月前
|
Android开发 开发者
Android企业级实战-界面篇-3
本文是《Android企业级实战-界面篇》系列的第三篇,主要介绍分割线和条形跳转框的实现方法,二者常用于设置和个人中心界面。文章通过具体代码示例展示了如何实现这两种UI组件,并提供了效果图。实现前需准备`dimens.xml`、`ids.xml`、`colors.xml`等文件,部分资源可参考系列第一、二篇文章。代码中详细说明了布局文件的配置,如分割线的样式定义和条形跳转框的组件组合,帮助开发者快速上手并应用于实际项目中。
|
4月前
|
JavaScript Linux 网络安全
Termux安卓终端美化与开发实战:从下载到插件优化,小白也能玩转Linux
Termux是一款安卓平台上的开源终端模拟器,支持apt包管理、SSH连接及Python/Node.js/C++开发环境搭建,被誉为“手机上的Linux系统”。其特点包括零ROOT权限、跨平台开发和强大扩展性。本文详细介绍其安装准备、基础与高级环境配置、必备插件推荐、常见问题解决方法以及延伸学习资源,帮助用户充分利用Termux进行开发与学习。适用于Android 7+设备,原创内容转载请注明来源。
755 76
|
2月前
|
XML Android开发 数据格式
Android企业级实战-界面篇-2
本文为《Android企业级实战-界面篇》系列第二篇,主要介绍三个UI模块的实现:用户资料模块、关注与粉丝统计模块以及喜欢和收藏功能模块。通过详细的XML代码展示布局设计,包括dimens、ids、colors配置文件的使用,帮助开发者快速构建美观且功能齐全的界面。文章结合实际效果图,便于理解和应用。建议配合第一篇文章内容学习,以获取完整工具类支持。
|
2月前
|
算法 Java Android开发
Android企业级实战-界面篇-1
本文详细介绍了Android企业级开发中界面实现的过程,涵盖效果展示、实现前准备及代码实现。作者通过自身经历分享了Android开发经验,并提供了`dimens.xml`、`ids.xml`、`colors.xml`和`strings.xml`等配置文件内容,帮助开发者快速构建规范化的UI布局。文章以一个具体的用户消息界面为例,展示了如何使用线性布局(LinearLayout)和相对布局(RelativeLayout)实现功能模块排列,并附带注意事项及使用方法,适合初学者和进阶开发者参考学习。
|
5月前
|
JavaScript 搜索推荐 Android开发
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
140 8
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
|
5月前
|
Dart 前端开发 Android开发
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
113 4
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
5月前
|
安全 Android开发 iOS开发
escrcpy:【技术党必看】Android开发,Escrcpy 让你无线投屏新体验!图形界面掌控 Android,30-120fps 超流畅!🔥
escrcpy 是一款基于 Scrcpy 的开源项目,使用 Electron 构建,提供图形化界面来显示和控制 Android 设备。它支持 USB 和 Wi-Fi 连接,帧率可达 30-120fps,延迟低至 35-70ms,启动迅速且画质清晰。escrcpy 拥有丰富的功能,包括自动化任务、多设备管理、反向网络共享、批量操作等,无需注册账号或广告干扰。适用于游戏直播、办公协作和教育演示等多种场景,是一款轻量级、高性能的 Android 控制工具。
257 1