当前位置: 首页 > news >正文

WEB 手柄 http通信,mcu端解析代码 2024/7/23 日志

WEB 手柄

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>WEB遥控器</title>
</head>
<style>* {margin: 0;padding: 0;overflow-y: hidden;overflow-x: hidden;}body {background-color: #09f811;color: aliceblue;}#play {transform-origin: top left;position: absolute;}@media only screen 
and (min-device-width : 320px) 
and (max-device-width : 480px) {#play {transform: scale(0.5);}
}@media only screen 
and (min-device-width : 481px) 
and (max-device-width : 768px) {#play {transform: scale(0.7);}
}@media only screen 
and (orientation : portrait) 
and (min-device-width : 768px) 
and (max-device-width : 1024px) {#play {transform: scale(0.8);}
}@media only screen 
and (orientation : landscape) 
and (min-device-width : 768px) 
and (max-device-width : 1024px) {#play {transform: scale(0.9);}
}@media only screen 
and (min-width : 1224px) {#play {transform: scale(1);}
}#box {gap: 0;display: grid;grid-template-columns: repeat(3, 1fr);grid-template-rows: repeat(3, 1fr);}#box3 {gap: 0;display: grid;grid-template-columns: repeat(3, 1fr);grid-template-rows: repeat(3, 1fr);}div[id^="t"] {border-radius: 25px;margin: 10px;text-align: center;width: 100px;height: 100px;background-color: black;font-size: 50px;display: flex;align-items: center;justify-content: center;}#t1 {grid-column: 3;grid-row: 2;transform: rotate(90deg)}#t2 {grid-column: 2;grid-row: 2;}#t3 {grid-column: 1;grid-row: 2;transform: rotate(90deg);}#t4 {grid-column: 2;transform: rotate(90deg);}#t5 {transform: rotate(90deg);grid-column: 2;grid-row: 3;}#t6,#t7 {font-size: 30px;transform: rotate(90deg);}#t8 {grid-column: 3;grid-row: 2;transform: rotate(90deg);}#t9 {grid-column: 2;grid-row: 2;}#t10 {grid-column: 1;grid-row: 2;transform: rotate(90deg);}#t11 {grid-column: 2;transform: rotate(90deg);}#t12 {grid-column: 2;grid-row: 3;transform: rotate(90deg);}div[id^="t"]:active {transform:scale(0.2);background-color: rgb(243, 94, 8);}#wifi {position: absolute;background-color: black;border-radius: 25px;font-size: 50px;width: 50px;height: 50px;right: 0;}#wifi:active {transform: scale(0.5);}#set {display: none;height: 100vh;position: relative;z-index: 2;background-color: black;}#but {position: absolute;width: 100vw;height: 5vh;bottom: 0;}#but:active {transform: scale(0.4);}#MQTT {width: 100vw;height: 50vh;}#diva {display: flex;}#LED {margin: 0;padding: 0;}#dy {display: none;}#dvfas {display: none;}#about {height: 5vh;width: 100vw;position: absolute;bottom: 0;}#about>p{transform: rotate(90deg);}#abouta{position: absolute;display: block;width: 100vw;background-color: white;height: 100vh;display: none;color: black;}#abouta>p{transform-origin: 50vw 50vw;transform: rotate(90deg);position: absolute;top:5vh;right: 80vw;}#abouta>p:hover{color: rgba(241, 8, 8, 0.835);}</style><body><div id="play"><div id="box"><div id="t1">↑</div><div id="t2">⚪</div><div id="t3">↓</div><div id="t4">←</div><div id="t5">→</div></div><div id="box2"><div id="t6">启动</div><div id="t7">暂停</div></div><div id="box3"><div id="t8">上</div><div id="t9">⚪</div><div id="t10">下</div><div id="t11">左</div><div id="t12">右</div></div></div><button id="about"><p>关于</p></button><div id="abouta"><p>点击空白返回<br>联系我们:<br>邮箱
<br>祝福您生活愉快!</p></div><div id="wifi" >★</div><div id="set" ><h1>MQTT管理</h1><div id="MQTT"><form class="fr"><span>MQTT服务器:</span><input type="text" id="mqttserver" name="dz" placeholder="填入服务器地址"><br><span>MQTT端口号:</span><input type="text" id="pot" name="port" placeholder="填入端口号"><br><span>MQTT密匙码:</span><input type="text" id="pasa" name="pass" placeholder="填入MQTT连接密匙"><button type="button" onclick="connected()">连接</button></form><div id="diva"><span>连接状态:</span><svg width="30" height="30" viewBox="0 0 100 100"><circle id="LED" cx="30" cy="30" r="26" stroke="black" stroke-width="3" fill="red" />连接中...</svg></div><p id="ts"></p><br><i id="jsre"></i><div id="dy"><form><span>设置订阅主题:</span><input type="text" id="subqq" name="subqq" placeholder="填入订阅主题"><button type="button" onclick="subee()">订阅</button></form><p id="subts"></p></div><div id="dvfas"><form><span>设置发布主题:</span><input type="text" id="pubqq" name="pubqq" placeholder="填入需要发布的消息"><button type="button" onclick="pubee()">发布</button></form><p id="pubts"></p></div></div><button id="but">返回</button></div><script>for (var i = 1; i <= 12; i++) {document.getElementById("t" + i).addEventListener("click", function () {var xhr = new XMLHttpRequest();xhr.open("GET", "/?cmd=" + this.id, true);xhr.send();var str = document.getElementById(this.id).textContent;console.log(str);})}connected = () => {var geta = document.getElementById('mqttserver').value;var getb = document.getElementById('pot').value;var getc = document.getElementById('pasa').value;if (geta == "" || getb == "" || getc == "") {document.getElementById("ts").innerHTML = "请输入完整";return;};console.log(geta);console.log(getb);console.log(getc);var xhr = new XMLHttpRequest();var str = "/MQTT?dz=" + geta + "&port=" + getb + "&pass=" + getc;xhr.open("GET", str, false);xhr.send();if (xhr.status == 200) {var LED = document.getElementById("LED");LED.setAttribute("fill", "green");document.getElementById("jsre").innerText = "恭喜您,成功连接MQTT!";document.getElementById("ts").innerHTML = "连接成功";document.getElementById("dy").style.display = "block";} else { document.getElementById("ts").innerHTML = "连接失败"; };};function subee() {var gea = document.getElementById('subqq').value;if (gea == "") {document.getElementById("subts").innerText = "请输入完整";return;};console.log(gea);var xhr = new XMLHttpRequest();var str = "/subqq?subqq=" + gea;xhr.open("GET", str, true);xhr.onreadystatechange = function () {if (xhr.readyState == 4 && xhr.status == 200) {document.getElementById("subts").innerText = "订阅成功";document.getElementById("dvfas").style.display = "block";};};xhr.send();};function pubee() {var gea = document.getElementById('pubqq').value;if (gea == "") {document.getElementById("subts").innerText = "请输入完整";return;};console.log(gea);var xhr = new XMLHttpRequest();var str = "/pubqq?pubqq=" + gea;xhr.open("GET", str, true);xhr.onreadystatechange = function () {if (xhr.readyState == 4 && xhr.status == 200) {document.getElementById("pubts").innerText = "发布成功";};};xhr.send();};document.getElementById("wifi").addEventListener("click", function () {var h1 = document.getElementById("set");h1.style.display = "block";});document.getElementById("but").addEventListener("click", function () {var h1 = document.getElementById("set");h1.style.display = "none";});document.getElementById("about").addEventListener("click", function () {var abouta=document.getElementById("abouta");abouta.style.display="block";abouta.addEventListener("click",function(){abouta.style.display="none";});});</script></body></html>

相关文章:

WEB 手柄 http通信,mcu端解析代码 2024/7/23 日志

WEB 手柄 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>WEB遥控器</title> </head> &l…...

cmake中的正则表达式

以下字符或者字符组合在cmake的正则表达式中的特殊含义&#xff1a; ^ 匹配输入的开始 $ 匹配输入的结束 . 匹配任意一个字符 \<char> 匹配一个字符&#xff0c;如.匹配字符.&#xff0c;\匹配字符\&#xff0c;\a匹配字符a [ ] 匹配在括号里面的任意字符&#xff0…...

05. Java 三大范式

1. 前言 在面向对象语言中涉及到诸多的设计模式&#xff0c;例如单例模式、适配器模式&#xff0c;设计模式的存在是为了让系统中的代码逻辑更加清晰&#xff0c;帮助开发者建立更加健壮的系统&#xff0c;同时满足易修改特性和易扩展特性。数据库设计时也存在类似设计模式的通…...

opencv 按键开启连续截图,并加载提示图片

背景图小图 键盘监听使用的是pynput 库 保存图片时使用了年月日时分秒命名 原图&#xff1a; from pynput import keyboard import cv2 import time# 键盘监听 def on_press(key):global jieglobal guanif key.char a:jie Trueelif key.char d:jie Falseelif key.char…...

Android-- 集成谷歌地图

引言 项目需求需要在谷歌地图&#xff1a; 地图展示&#xff0c;设备点聚合&#xff0c;设备站点&#xff0c;绘制点和区域等功能。 我只针对我涉及到的技术做一下总结&#xff0c;希望能帮到开始接触谷歌地图的伙伴们。 集成步骤 1、在项目的modle的build.gradle中添加依赖如…...

Jvm是如何处理异常的

异常抛出 当Java程序运行时遇到无法处理的情况时,会抛出一个异常(比如在一个方法中如果发生异常),这时会创建一个异常对象,并转交给JVM,该异常对象包含异常名称,异常描述以及异常发生时应用程序的状态。创建异常对象并转交给JVM的过程称为抛出异常。 异常捕捉 当JVM检测…...

recursion depth exceeded” error

有些时候不可以用jax.jit装饰器 参考资料&#xff1a;使用 JAX 后端在 Keras 3 中训练 GAN |由 Khawaja Abaid |中等 (medium.com)...

虚拟现实和增强现实技术系列—Expressive Talking Avatars

文章目录 1. 概述2. 背景介绍3. 数据集3.1 设计标准3.2 数据采集 4. 方法4.1 概述4.2 架构4.3 目标函数 5. 实验评测5.1 用户研究5.2 我们方法的结果5.3 比较与消融研究 1. 概述 支持远程协作者之间的交互和沟通。然而&#xff0c;明确的表达是出了名的难以创建&#xff0c;主…...

网站验证:确保网络安全与信任的重要步骤

网站验证&#xff1a;确保网络安全与信任的重要步骤 引言 在数字时代&#xff0c;网站验证是确保网络安全和建立用户信任的关键措施。随着网络诈骗和恶意软件的日益增多&#xff0c;验证网站的真实性和安全性变得尤为重要。本文将探讨网站验证的重要性、常见的验证方法以及如…...

C语言——字符串比较函数strcmp和strncmp

目录 strcmp 函数原型如下&#xff1a; 示例 注意事项 strcmp自实现代码&#xff1a; strncmp 函数 函数原型&#xff1a; 参数&#xff1a; 返回值&#xff1a; 特点&#xff1a; 两者之间的区别和联系 strcmp strcmp 是 C 语言标准库中的一个函数&#xff0c;用于…...

redis的集群模式

目录 1. 为什么使用redis集群 2. 主从模式 2.1修改配置文件 2.2 开启三台redis服务 2.3配置主从关系 3. 哨兵模式 3.1 监控功能 3.2 选举的机制 3.3 准备条件 4. 去中心化模式 4.1 准备三主三从 4.2 启动redis 4.3 分配槽以及主从关系 4.4 命令行的客户端 redis提供…...

基于微信小程序+SpringBoot+Vue的青少年科普教学系统平台(带1w+文档)

基于微信小程序SpringBootVue的青少年科普教学系统平台(带1w文档) 基于微信小程序SpringBootVue的青少年科普教学系统平台(带1w文档) 这个工具就是解决上述问题的最好的解决方案。它不仅可以实时完成信息处理&#xff0c;还缩短高校教师成果信息管理流程&#xff0c;使其系统化…...

智能听觉:从任务特定的机器学习到基础模型

关键词&#xff1a;计算机听觉、音频基础模型、多模态学习、声音事件检测 声音无处不在&#xff0c;弥漫于我们生活的每一个角落。鸟儿向伴侣倾诉心意的歌声&#xff0c;浓缩咖啡机中蒸汽的嘶嘶作响&#xff0c;午后阳光下昆虫振翅的嗡嗡声&#xff0c;金属屋顶上雨滴跳跃的滴答…...

14、如何⽤DDD设计微服务代码模型

在完成领域模型设计后&#xff0c;接下来我们就可以开始微服务的设计和 落地了。在微服务落地前&#xff0c;⾸先要确定微服务的代码结构&#xff0c;也就是我 下⾯要讲的微服务代码模型。 只有建⽴了标准的微服务代码模型和代码规范后&#xff0c;我们才可以将 领域对象映射到…...

ArcGIS Pro SDK (九)几何 12 多面体

ArcGIS Pro SDK &#xff08;九&#xff09;几何 12 多面体 文章目录 ArcGIS Pro SDK &#xff08;九&#xff09;几何 12 多面体1 通过拉伸多边形或折线构建多面体2 多面体属性3 构建多面体4 通过MultipatchBuilderEx构建多面体5 从另一个多面体构建多面体6 从 3D 模型文件构建…...

二次元手游《交错战线》游戏拆解

交错战线游戏拆解案 游戏亮点即核心趣味 一、关键词&#xff1a; 回合制游戏、二次元、机甲、横板、剧情、养成、异星探索。 二、游戏亮点&#xff1a; 符合目标群体审美的原画。 三、核心趣味&#xff1a; 抽卡、肝或者氪金解锁新皮肤。 核心玩法及系统规则 核心玩法&…...

【BUG】已解决:Downgrade the protobuf package to 3.20.x or lower.

Downgrade the protobuf package to 3.20.x or lower. 目录 Downgrade the protobuf package to 3.20.x or lower. 【常见模块错误】 【解决方案】 欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 欢迎来到我的主页&#xff0c;我是博主英杰&#xff0c;211科班出身…...

Java开发之Redis

1、非关系型数据库、快、高并发、功能强大 2、为什么快&#xff1f;内存单线程 非阻塞的IO多路复用有效的数据类型/结构 3、应用&#xff1a;支持缓存、支持事务、持久化、发布订阅模型、Lua脚本 4、数据类型&#xff1a; 5 种基础数据类型&#xff1a;String&#xff08;字…...

Java面试八股之 Spring Bean的生命周期

Spring Bean的生命周期 实例化&#xff08;Instantiation&#xff09;&#xff1a;Spring容器根据Bean定义信息创建Bean的实例&#xff0c;通常通过无参构造函数进行。 依赖注入&#xff08;Dependency Injection&#xff0c;DI&#xff09;&#xff1a;Spring容器按照Bean定…...

SQL中的函数

目录 前言 一、系统内置函数 1、数学函数 2、日期和时间函数 3、聚合函数 4、字符串函数 二、自定义函数 1、标量函数的创建与调用 2、内嵌表值函数的创建与调用 3、多语句表值函数的创建与调用 前言 函数是由一个或多个 T-SQL 语句组成的子程序&#xff0c;可用于封…...

智慧医疗能源事业线深度画像分析(上)

引言 医疗行业作为现代社会的关键基础设施,其能源消耗与环境影响正日益受到关注。随着全球"双碳"目标的推进和可持续发展理念的深入,智慧医疗能源事业线应运而生,致力于通过创新技术与管理方案,重构医疗领域的能源使用模式。这一事业线融合了能源管理、可持续发…...

.Net框架,除了EF还有很多很多......

文章目录 1. 引言2. Dapper2.1 概述与设计原理2.2 核心功能与代码示例基本查询多映射查询存储过程调用 2.3 性能优化原理2.4 适用场景 3. NHibernate3.1 概述与架构设计3.2 映射配置示例Fluent映射XML映射 3.3 查询示例HQL查询Criteria APILINQ提供程序 3.4 高级特性3.5 适用场…...

Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例

使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件&#xff0c;常用于在两个集合之间进行数据转移&#xff0c;如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model&#xff1a;绑定右侧列表的值&…...

从深圳崛起的“机器之眼”:赴港乐动机器人的万亿赛道赶考路

进入2025年以来&#xff0c;尽管围绕人形机器人、具身智能等机器人赛道的质疑声不断&#xff0c;但全球市场热度依然高涨&#xff0c;入局者持续增加。 以国内市场为例&#xff0c;天眼查专业版数据显示&#xff0c;截至5月底&#xff0c;我国现存在业、存续状态的机器人相关企…...

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...

STM32标准库-DMA直接存储器存取

文章目录 一、DMA1.1简介1.2存储器映像1.3DMA框图1.4DMA基本结构1.5DMA请求1.6数据宽度与对齐1.7数据转运DMA1.8ADC扫描模式DMA 二、数据转运DMA2.1接线图2.2代码2.3相关API 一、DMA 1.1简介 DMA&#xff08;Direct Memory Access&#xff09;直接存储器存取 DMA可以提供外设…...

[ICLR 2022]How Much Can CLIP Benefit Vision-and-Language Tasks?

论文网址&#xff1a;pdf 英文是纯手打的&#xff01;论文原文的summarizing and paraphrasing。可能会出现难以避免的拼写错误和语法错误&#xff0c;若有发现欢迎评论指正&#xff01;文章偏向于笔记&#xff0c;谨慎食用 目录 1. 心得 2. 论文逐段精读 2.1. Abstract 2…...

屋顶变身“发电站” ,中天合创屋面分布式光伏发电项目顺利并网!

5月28日&#xff0c;中天合创屋面分布式光伏发电项目顺利并网发电&#xff0c;该项目位于内蒙古自治区鄂尔多斯市乌审旗&#xff0c;项目利用中天合创聚乙烯、聚丙烯仓库屋面作为场地建设光伏电站&#xff0c;总装机容量为9.96MWp。 项目投运后&#xff0c;每年可节约标煤3670…...

Mobile ALOHA全身模仿学习

一、题目 Mobile ALOHA&#xff1a;通过低成本全身远程操作学习双手移动操作 传统模仿学习&#xff08;Imitation Learning&#xff09;缺点&#xff1a;聚焦与桌面操作&#xff0c;缺乏通用任务所需的移动性和灵活性 本论文优点&#xff1a;&#xff08;1&#xff09;在ALOHA…...

Proxmox Mail Gateway安装指南:从零开始配置高效邮件过滤系统

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐&#xff1a;「storms…...