Android 热点二维码简单示例

Android 热点二维码简单示例

一、前言

Android 原生设置有热点二维码分享功能,有些系统应用也会有这个需求。
下面看看是如何实现的。
本文是一个比较简单的内容。

二、热点二维码生成实现

1、效果

在这里插入图片描述

整个应用就一个普通的Activity,+显示一个按钮和二维码图片;

上面的输入框默认是热点密码的格式,修改输入后可以重新生成;
还添加了点击二维码图片,放大效果,如下图所示:
在这里插入图片描述

一般新的手机使用相机扫描可以识别连接热点,或者wifi设置里面也可以扫描连接热点;

上面这个二维码也可以直接打印使用,

如果你的wifi名称修改成test,密码修改成12345678,别人在附近扫描这个二维码就能连接。

2、主要知识点

(1)热点密码字符串格式
固定格式格式:WIFI:T:WifiType;S:WifiName;P:WifiPassword;;示例:
//加密类型:WPA2,wifi名称:test,wifi密码:12345678
WIFI:T:WPA2;S:test;P:12345678;;//没有密码的wifi:
WIFI:T:nopass;S:test;P:;;
(2)字符串生成二维码图片:
implementation 'com.google.zxing:core:3.4.1'
app build.gradle 导入zxing包就可以调用相关方法生成Bitmap对象放到ImageView显示。//字符串上层二维码Bitmap对象封装方法:public static Bitmap createQrcode(String text) {Log.v(TAG, "createQrcode text = " + text);if (TextUtils.isEmpty(text)) {return null;}try {String contents = new String(text.getBytes("UTF-8"), "ISO-8859-1");MultiFormatWriter formatWriter = new MultiFormatWriter();BitMatrix bitMatrix = formatWriter.encode(contents, BarcodeFormat.QR_CODE, 800, 800);return bitMatrix2Bitmap(bitMatrix);} catch (Exception e) {e.printStackTrace();}return null;}

3、demo代码

两个类:一个Activity类和一个工具类。

(1)MainActivity.java
package com.example.qrcode;import android.app.Dialog;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.Toast;import androidx.activity.EdgeToEdge;
import androidx.appcompat.app.AlertDialog;
import androidx.appcompat.app.AppCompatActivity;public class MainActivity extends AppCompatActivity implements View.OnClickListener {EditText et_input;Button btn_create_qrcode;ImageView imageView;String TAG = "MainActivity";@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);EdgeToEdge.enable(this);setContentView(R.layout.activity_main);initView();initData();initEvent();}private void initView() {btn_create_qrcode = findViewById(R.id.btn_create_qrcode);et_input = findViewById(R.id.et_input);imageView = findViewById(R.id.iv_qrcode);}private void initData() {//TestString testText = "WIFI:T:WPA2;S:test;P:12345678;;";//wifi名称:test,密码:12345678//String testText = QrcodeUtils.createQrcode(QrcodeUtils.getHotspotQrcodeString(this)); //热点二维码字符串imageView.setImageBitmap(QrcodeUtils.createQrcode(testText));et_input.setText(testText);}private void initEvent() {btn_create_qrcode.setOnClickListener(this);imageView.setOnClickListener(this);}//点击事件@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.btn_create_qrcode:Toast.makeText(this, "创建了二维码", Toast.LENGTH_SHORT).show();String text = et_input.getText().toString();Log.i(TAG, "text: " + text);imageView.setImageBitmap(QrcodeUtils.createQrcode(text));break;case R.id.iv_qrcode:Toast.makeText(this, "点击了二维码", Toast.LENGTH_SHORT).show();View view = getLayoutInflater().inflate(R.layout.dialog_qrcode, null);ImageView imageView = view.findViewById(R.id.iv_qrcode_dialog);imageView.setImageBitmap(QrcodeUtils.createQrcode("WIFI:T:WPA2;S:test;P:12345678;;"));Dialog alertDialog = new AlertDialog.Builder(this).setView(view).create();alertDialog.show();break;}}
}

上面就是一个普通的Activity代码,比较简单易懂。

(2)QrcodeUtils.java
package com.example.qrcode;import com.google.zxing.BarcodeFormat;
import com.google.zxing.MultiFormatWriter;
import com.google.zxing.common.BitMatrix;import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Bitmap.Config;
import android.graphics.Color;
import android.util.Log;
import android.net.wifi.SoftApConfiguration;
import android.net.wifi.WifiManager;
import android.text.TextUtils;public class QrcodeUtils {private static final String TAG = QrcodeUtils.class.getSimpleName();//字符串生成Bitmap对象public static Bitmap createQrcode(String text) {Log.v(TAG, "createQrcode text = " + text);if (TextUtils.isEmpty(text)) {return null;}try {String contents = new String(text.getBytes("UTF-8"), "ISO-8859-1");MultiFormatWriter formatWriter = new MultiFormatWriter();BitMatrix bitMatrix = formatWriter.encode(contents, BarcodeFormat.QR_CODE, 800, 800);return bitMatrix2Bitmap(bitMatrix);} catch (Exception e) {e.printStackTrace();}return null;}private static Bitmap bitMatrix2Bitmap(BitMatrix matrix) {int w = matrix.getWidth();int h = matrix.getHeight();int[] rawData = new int[w * h];for (int i = 0; i < w; i++) {for (int j = 0; j < h; j++) {int color = Color.WHITE;if (matrix.get(i, j)) {color = Color.BLACK;}rawData[i + (j * w)] = color;}}Bitmap bitmap = Bitmap.createBitmap(w, h, Config.RGB_565);bitmap.setPixels(rawData, 0, w, 0, 0, w, h);return bitmap;}//获取热点二维码规则的字符串public static String getHotspotQrcodeString(Context context) {WifiManager wifiManager = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);if (wifiManager == null) {return null;}SoftApConfiguration config = wifiManager.getSoftApConfiguration(); //getSoftApConfiguration()方法需要导入framework jar包才能章程编过String wifiName = "";String wifiPassWord = "";wifiName = config.getSsid();wifiPassWord = config.getPassphrase();int securityType = config.getSecurityType();String security = "WPA2";//判断是否设置了热点密码,如果未设置热点密码不用设置密码字符串if (securityType == SoftApConfiguration.SECURITY_TYPE_OPEN) {wifiPassWord = "";security = "nopass";}StringBuilder build = new StringBuilder();build.append("WIFI:T:").append(security).append(";S:").append(wifiName).append(";P:").append(wifiPassWord).append(";;");return build.toString();}}

上面就是一个工具类,主要包含两个工具方法:

一个是字符串创建二维码Bitmap对象;

一个是获取热点二维码的字符串;

(3)热点二维码

上面的demo代码,默认是普通字符串的二维码生成;

如果要换成本机设备的热点二维码的生成,把字符串生成的方法替换成 getHotspotQrcodeString()方法就行;

但是要注意的是热点信息的获取是要系统签名权限的;

所以要热点字符串生成导入系统签名的jks;

并且需要在AndroidManifest中声明uid:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:sharedUserId="android.uid.system">

还有就是要添加权限:

 <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />

还有就是要导入系统的framework 的jar包:

未导入系统jar包下面的代码会编译错误:
WifiManager.getSoftApConfiguration();

4、扩展一下

其实不仅仅是手机热点的wifi可以用二维码,普通的wifi也是可以使用二维码;

只要把上面的账号和密码替换就行;后面就可以提供二维码给别人进行扫描连接wifi;

所以在现实场景中也可以提前生成对应的wifi名称和密码的二维码,保留使用;

特别是很长的wifi名称或者密码的情况,使用二维码扫描连接更加方便。

5、资源下载

项目代码和apk应用代码下载路径:

https://download.csdn.net/download/wenzhi20102321/90640480

apk可以直接下载安装使用;可以定制自己需要的wifi账号和密码的二维码图片。

三、其他

1、Android 热点二维码简单示例小结

(1)热点二维码固定格式格式:WIFI:T:WifiType;S:WifiName;P:WifiPassword;;
(2)生成二维码图片使用zxing包的相关类
(3)如果应用需要生成设备当时的热点二维码图片,需要系统签名权限命令

手机联系人的二维码呢?也是这样的二维码吗?

其实这些码都不一样,像微信个人二维码,挪车码,支付宝的码,

这些二维码都是包含网址和相关信息的,需要通过具体服务器校验才能跳转到另外界面。

2、之前的二维码和热点介绍

Android二维码图片生成和二维码扫描软件的设计

https://blog.csdn.net/wenzhi20102321/article/details/53316179

Android 热点分享二维码功能简单介绍

https://blog.csdn.net/wenzhi20102321/article/details/142603112

之前没介绍这么具体,并且没有提供到apk和源码。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/902030.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

uv:重新定义Python开发效率的下一代工具链

在Python生态系统中&#xff0c;包管理和项目工具链的复杂性一直是开发者面临的一大挑战。从依赖管理、虚拟环境创建到多版本Python切换&#xff0c;传统的工具链&#xff08;如pip、virtualenv、poetry等&#xff09;虽然功能强大&#xff0c;但操作繁琐、性能不足的问题长期存…

T101D加固平板电脑:无人机地面站的高效智能控制核心

随着无人机技术在应急救援、农业监测、军事侦察等领域的广泛应用&#xff0c;对地面控制设备的要求也日益提高。鲁成伟业推出的T101D加固平板电脑凭借其高性能、强防护和专业化设计&#xff0c;成为无人机地面站的核心控制终端&#xff0c;为复杂环境下的作业提供了可靠支持。 …

Datawhale AI春训营】AI + 新能源(发电功率预测)Task1

赛题链接 官网 新能源发电功率预测赛题进阶方案 下面是ai给的一些建议 新能源发电功率预测赛题进阶方案 一、时序特性深度挖掘 1. 多尺度周期特征 # 分钟级周期编码 train[15min_index] (train[hour]*4 train[minute]//15)# 周周期特征 train[weekday] pd.to_datetime…

山东科技大学深度学习考试回忆

目录 一、填空&#xff08;五个空&#xff0c;十分&#xff09; 二、选择题(五个&#xff0c;十分&#xff09; 三、判断题&#xff08;五个&#xff0c;五分&#xff09; 四、论述题&#xff08;四个&#xff0c;四十分&#xff09; 五、计算题&#xff08;二个&#xff…

Redis线上操作最佳实践有哪些?

大家好&#xff0c;我是锋哥。今天分享关于【Redis线上操作最佳实践有哪些?】面试题。希望对大家有帮助&#xff1b; Redis线上操作最佳实践有哪些? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 在使用 Redis 时&#xff0c;尤其是在生产环境中&#xff0c;合理…

mac中的zip文件压缩与压缩文件中指定目录删除

问题 在使用mac的图形界面压缩文件后&#xff0c;往往那个压缩文件中带有__MACOSX文件&#xff0c;但是&#xff0c;这个文件夹又是我们不需要的目录&#xff0c;所有&#xff0c;需要对mac图形化界面压缩后的文件目录进行删除&#xff0c;改如何做&#xff1f; 检查压缩文件…

【记录】服务器用命令开启端口号

这里记录下如何在服务器上开启适用于外界访问的端口号。 方法 1 使用防火墙 1 su &#xff0c;命令 输入密码 切换到root节点 2 开启防火墙 systemctl start firewalld3 配置开放端口 firewall-cmd --zonepublic --add-port8282/tcp --permanent4 重启防火墙 firewall-cmd…

深度学习-torch,全连接神经网路

3. 数据集加载案例 通过一些数据集的加载案例&#xff0c;真正了解数据类及数据加载器。 3.1 加载csv数据集 代码参考如下 import torch from torch.utils.data import Dataset, DataLoader import pandas as pd ​ ​ class MyCsvDataset(Dataset):def __init__(self, fil…

C++/Python实现RGB和HSI相互转换

1--C版本 #include <opencv2/opencv.hpp> #include <iostream> #include <cmath>// RGB to HSI cv::Vec3f RGBtoHSI(cv::Vec3b rgb) {float B rgb[0] / 255.0f;float G rgb[1] / 255.0f;float R rgb[2] / 255.0f;float num 0.5f * ((R - G) (R - B));f…

【Linux我做主】make和makefile自动化构建

make和makefile自动化构建 make和makefile自动化构建github地址前言背景介绍为什么需要make和makefile&#xff1f; make和makefile解析什么是make和makefile依赖关系和依赖方法核心语法结构简单演示编译清理 多阶段编译示例 make时执行的顺序场景1&#xff1a;clean目标在前(特…

Qt 入门 5 之其他窗口部件

Qt 入门 5 之其他窗口部件 本文介绍的窗口部件直接或间接继承自 QWidget 类详细介绍其他部件的功能与使用方法 1. QFrame 类 QFrame类是带有边框的部件的基类。它的子类包括最常用的标签部件QLabel另外还有 QLCDNumber、QSplitter,QStackedWidget,QToolBox 和 QAbstractScrol…

JAVA学习-多线程

线程 线程(Thread)是一个程序内部的一条执行流程。 程序中如果只有一条执行流程&#xff0c;那这个程序就是单线程的程序。 线程的常用方法及构造器&#xff1a; Thread提供的常用方法public void run() 线程的任务方法public void start() 启动线程public String getName() …

Github 2025-04-19Rust开源项目日报 Top10

根据Github Trendings的统计,今日(2025-04-19统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Rust项目10Python项目1Rust: 构建可靠高效软件的开源项目 创建周期:5064 天开发语言:Rust协议类型:OtherStar数量:92978 个Fork数量:12000…

OpenLayers:视图变换的方法

一、什么是视图变换&#xff1f; 视图变换就是指视图的 extent&#xff08;范围&#xff09;、center&#xff08;中心点&#xff09;、zoom&#xff08;缩放级别&#xff09;、 resolution&#xff08;分辨率&#xff09;、rotation&#xff08;旋转角&#xff09;等参数发生…

数字孪生火星探测车,星际探索可视化

运用图扑构建数字孪生火星探测车&#xff0c;高精度还原外观与内部构造。实时映射探测车在火星表面的移动、探测作业及设备状态&#xff0c;助力科研人员远程监测、分析数据&#xff0c;为火星探索任务提供可视化决策支持。

【NLP 66、实践 ⑰ 基于Agent + Prompt Engineering文章阅读】

你用什么擦干我的眼泪 莎士比亚全集 工业纸巾 还是你同样泛红的眼睛 —— 4.19 一、⭐【核心函数】定义大模型调用函数 call_large_model prompt&#xff1a;用户传入的提示词&#xff08;如 “请分析这篇作文的主题”&#xff09;&#xff0c;指导模型执行任务 client&…

黑马Java基础笔记-1

JVM&#xff0c;JDK和JRE JDK是java的开发环境 JVM虚拟机&#xff1a;Java程序运行的地方 核心类库&#xff1a;Java已经写好的东西&#xff0c;我们可以直接用。 System.out.print中的这些方法就是核心库中的所包含的 开发工具: javac&#xff08;编译工具&#xff09;、java&…

PR第一课

目录 1.新建 2.PR内部设置 3.导入素材 4.关于素材窗口 5.关于编辑窗口 6.序列的创建 7.视频、图片、音乐 7.1 带有透明通道的素材 8.导出作品 8.1 打开方法 8.2 导出时&#xff0c;需要修改的参数 1.新建 2.PR内部设置 随意点开 编辑->首选项 中的任意内容&a…

Xcode16 调整 Provisioning Profiles 目录导致证书查不到

cronet demo 使用的 ninja 打包&#xff0c;查找 Provisioning Profiles 路径是 ~/Library/MobileDevice/Provisioning Profiles&#xff0c;但 Xcode16 把该路径改为了 ~/Library/Developer/Xcode/UserData/Provisioning Profiles&#xff0c;导致在编译 cronet 的demo 时找不…

【更新完毕】2025华中杯C题数学建模网络挑战赛思路代码文章教学数学建模思路:就业状态分析与预测

完整内容请看文末最后的推广群 先展示文章和代码、再给出四个问题详细的模型 基于多模型下的就业状态研究 摘要 随着全球经济一体化和信息技术的迅猛发展&#xff0c;失业问题和就业市场的匹配性问题愈加突出。为了解决这一问题&#xff0c;本文提出了一种基于统计学习和机器学…