esp32触发相机

esp32触发相机,测试成功上升沿触发

串口发送命令 up 20000 1 20000 触发

#include <Arduino.h>

const int outputPin = 12;  // 输出引脚
String inputCommand = "";  // 串口输入缓冲区

// 解析命令参数,例如 "up 10 5" 解析为 delayMicrosecondsTime=10, repeatCount=5



// 解析命令参数,例如 "up 10 5" 解析为 delayMicrosecondsTime=10, repeatCount=5
bool parseParameters(String command, int &delayMicrosecondsTime, int &repeatCount) {
  int firstSpace = command.indexOf(' '); // 查找第一个空格位置
  if (firstSpace < 0) return false;     // 没有参数

  int secondSpace = command.indexOf(' ', firstSpace + 1); // 查找第二个空格位置
  if (secondSpace < 0) return false;                     // 参数不完整

  // 提取参数并转换为整数
  String delayMicrosecondsStr = command.substring(firstSpace + 1, secondSpace);
  String repeatStr = command.substring(secondSpace + 1);

  delayMicrosecondsTime = delayMicrosecondsStr.toInt();
  repeatCount = repeatStr.toInt();

  // 检查参数是否合法
  return delayMicrosecondsTime > 0 && repeatCount > 0;
}



// 解析命令参数,例如 "up 10 5 3" 解析为 delayMicrosecondsTime=10, repeatCount=5, additionalParam=3
bool parseParametersThree(String command, int &delayMicrosecondsTime, int &repeatCount, int &additionalParam) {
  int firstSpace = command.indexOf(' '); // 查找第一个空格位置
  if (firstSpace < 0) return false;     // 没有参数

  int secondSpace = command.indexOf(' ', firstSpace + 1); // 查找第二个空格位置
  if (secondSpace < 0) return false;                     // 参数不完整

  int thirdSpace = command.indexOf(' ', secondSpace + 1); // 查找第三个空格位置
  if (thirdSpace < 0) return false;                      // 参数不完整

  // 提取参数并转换为整数
  String delayMicrosecondsStr = command.substring(firstSpace + 1, secondSpace);
  String repeatStr = command.substring(secondSpace + 1, thirdSpace);
  String additionalStr = command.substring(thirdSpace + 1);

  delayMicrosecondsTime = delayMicrosecondsStr.toInt();
  repeatCount = repeatStr.toInt();
  additionalParam = additionalStr.toInt();

  // 检查参数是否合法
  return delayMicrosecondsTime > 0 && repeatCount > 0 && additionalParam > 0;
}

void handleUpCommand(String command) {
  int delayMicrosecondsTime = 0, repeatCount = 0, additionalParam = 0;
  if (parseParametersThree(command, delayMicrosecondsTime, repeatCount, additionalParam)) {
    Serial.println("Triggering UP signal...");
    for (int i = 0; i < repeatCount; i++) {
      digitalWrite(outputPin, HIGH); // 输出高电平
      delayMicroseconds(additionalParam);              // 等待
      digitalWrite(outputPin, LOW);  // 恢复低电平
      delayMicroseconds(delayMicrosecondsTime);              // 等待间隔
    }
  } else {
    Serial.println("Invalid parameters for 'up' command");
  }
}

void handleDownCommand(String command) {
  int delayMicrosecondsTime = 0, repeatCount = 0;
  if (parseParameters(command, delayMicrosecondsTime, repeatCount)) {
    Serial.println("Triggering DOWN signal...");
    for (int i = 0; i < repeatCount; i++) {
      digitalWrite(outputPin, LOW);  // 输出低电平
      delayMicroseconds(delayMicrosecondsTime);              // 等待
      digitalWrite(outputPin, HIGH); // 恢复高电平
      delayMicroseconds(delayMicrosecondsTime);              // 等待间隔
    }
  } else {
    Serial.println("Invalid parameters for 'down' command");
  }
}

void parseCommand(String command) {
  command.trim(); // 去掉多余的空格或换行符
  if (command.startsWith("up")) {
    handleUpCommand(command);
  } else if (command.startsWith("down")) {
    handleDownCommand(command);
  } else {
    Serial.println("Invalid command! Use 'up' or 'down'");
  }
}

void setup() {
  pinMode(outputPin, OUTPUT);   // 设置输出引脚
  digitalWrite(outputPin, LOW); // 初始化输出为低电平
  Serial.begin(9600);           // 初始化串口通信
}

void loop() {
  // 检查是否有串口输入
  while (Serial.available() > 0) {
    char receivedChar = Serial.read();
    if (receivedChar == '\n') { // 检测到回车符,执行命令
      parseCommand(inputCommand);
      inputCommand = ""; // 清空输入缓冲区
    } else {
      inputCommand += receivedChar; // 拼接命令字符
    }
  }
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

利用图像识别给CAD图纸找不同

✨✨ 欢迎大家来访Srlua的博文&#xff08;づ&#xffe3;3&#xffe3;&#xff09;づ╭❤&#xff5e;✨✨ &#x1f31f;&#x1f31f; 欢迎各位亲爱的读者&#xff0c;感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢&#xff0c;在这里我会分享我的知识和经验。&am…

【CSP CCF记录】201712-2第12次认证 游戏

题目 样例输入1 5 2 样例输出1 3 样例输入2 7 3 样例输出2 4 代码 没有技术含量的一道题 #include<bits/stdc.h> using namespace std; int main() {int n,k;int a[1010]{0}; // 标记小朋友是否被淘汰 cin>>n>>k;int i0,num0,mn; while(m!1){i1; if(a[i]!1…

Unity图形学之BRDF双向反射分布函数

1.描述了入射光线在非透明物体表面如何进行反射&#xff0c;也就是说多少光发生了漫反射&#xff0c;多少光发生了镜面反射 BRDF 函数计算的是“特定反射方向的光强与入射光强的比例” 2.各向异性 与 均向性 相反&#xff0c;是指在不同方向具有不同行为的性质&#xff0c;也就…

华为ENSP--BGP路由协议实验详解

项目背景 随着A公司网络规模的增长和新业务对互联网接入速度及稳定性需求的提升&#xff0c;公司决定升级其网络设施。为此&#xff0c;A公司向运营商B租用了两条线路以接入网络&#xff0c;旨在提高网络资源的利用率&#xff0c;并增强网络的安全性、稳定性和可靠性&#xff0…

Springboot项目搭建(5)-前端注册界面

1.创建项目文件 news&#xff1a;为后端IDE文件 news_client&#xff1a;为前端VSCode文件 在 ..\news\news_client 中启用cmd/PowerShell 查看当前 npm 配置的注册表&#xff08;registry&#xff09;地址是否在https://registry.npmmirror.com 如果不在&#xff0c;可在cd…

Centos 7 系统 openGauss 3.1.0 一主两备集群安装部署指南

现供职于某上市互联网公司担任DBA Oracle & PG ACE称号&#xff0c; 拥有 Oracle OCM、AWS、以及部分国产数据库等产品认证。 喜欢技术分享&#xff0c;热爱交友&#xff0c;也热爱健身。 2019年加入墨天轮&#xff0c;目前已发表了一百多篇原创文章&#xff0c;曾多次…

w~视觉~3D~合集3

我自己的原文哦~ https://blog.51cto.com/whaosoft/12538137 #SIF3D 通过两种创新的注意力机制——三元意图感知注意力&#xff08;TIA&#xff09;和场景语义一致性感知注意力&#xff08;SCA&#xff09;——来识别场景中的显著点云&#xff0c;并辅助运动轨迹和姿态的预测…

TypeScript 系统学习 开篇

想学习 TypeScript 的小伙伴看过来&#xff0c;本文将带你一步步学习 TypeScript 入门相关的十四个知识点&#xff0c;详细的内容大纲请看下图&#xff1a; 一、TypeScript 是什么 TypeScript 是一种由微软开发的自由和开源的编程语言。它是 JavaScript 的一个超集&#xff0c…

计算机网络socket编程(5)_TCP网络编程实现echo_server

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 计算机网络socket编程(5)_TCP网络编程实现echo_server 收录于专栏【计算机网络】 本专栏旨在分享学习计算机网络的一点学习笔记&#xff0c;欢迎大家在评论区交…

Stable Diffusion 3详解

&#x1f33a;系列文章推荐&#x1f33a; 扩散模型系列文章正在持续的更新&#xff0c;更新节奏如下&#xff0c;先更新SD模型讲解&#xff0c;再更新相关的微调方法文章&#xff0c;敬请期待&#xff01;&#xff01;&#xff01;&#xff08;本文及其之前的文章均已更新&…

网络安全原理与技术思考题/简答题

作业1&#xff08;第1章、第2章、第8章&#xff09; 1. 网络安全的基本属性有哪些&#xff1f;简单解释每个基本属性的含义。网络安全的扩展属性包括哪些&#xff1f; 基本属性&#xff1a; 1.机密性(Confidentiality)&#xff1a; 含义&#xff1a;确保信息不被未授权的用户…

【大数据学习 | Spark-Core】Spark的分区器(HashPartitioner和RangePartitioner)

之前学过的kv类型上面的算子 groupby groupByKey reduceBykey sortBy sortByKey join[cogroup left inner right] shuffle的 mapValues keys values flatMapValues 普通算子&#xff0c;管道形式的算子 shuffle的过程是因为数据产生了打乱重分&#xff0c;分组、排序、join等…

Java代码实现数字信封

1. 前言 本篇博客是工作经验总结&#xff0c;如果您发现此篇博客有疏漏或有待改进之处&#xff0c;欢迎评论区交流。 2. 数字信封 数字信封使用的是接收者的非对称密钥对。即&#xff1a;用接收者的公钥加密&#xff0c;且只能由接收者的私钥解密。其实现过程如下&#xff1a;…

第 4 章 Java 并发包中原子操作类原理剖析

原子变量操作类 AtomicLong 是原子性递增或者递减类&#xff0c;其内部使用 Unsafe 来实现&#xff0c;AtomicLong类也是在 rt.jar 包下面的&#xff0c;AtomicLong 类就是通过 BootStarp 类加载器进行加载的。这里的原子操作类都使用 CAS 非阻塞算法 private static final lon…

Android调起系统分享图片到其他应用

Android调起系统分享图片到其他应用 有时候分享不想接第三方的&#xff0c;其实如果你的分享要求不是很高&#xff0c;调系统的分享也是可以的。 一、思路&#xff1a; 用intent.action Intent.ACTION_SEND 二、效果图&#xff1a; 三、关键代码&#xff1a; //这个是分享…

C++中虚继承为什么可以解决菱形继承的数据冗余问题

在C中菱形继承会有数据冗余的问题发生&#xff0c;我们可以使用虚继承来解决&#xff0c;那虚继承的原理是什么&#xff0c;为什么它可以解决这个问题。 菱形继承的数据冗余问题 class A { public:int data; };class B : public A {};class C : public A {};class D : public…

LSA详情与特殊区域

LSA是构成LSDB的重要原材料&#xff0c;在OSPF中发挥很大作用。 报文 通用头部 LS age&#xff1a;LSA寿命&#xff0c;0-3600s Options&#xff1a;可选项 LS type&#xff1a;LSA类型&#xff0c;三要素之一 Link State ID&#xff1a;LSAID 三要素之一 Advertising Ro…

Kubeadm 安装 Kubernetes 高可用集群 v1.30.0

1、修改主机名&#xff08;各个节点&#xff09; hostnamectl set-hostname xxx2、hosts 文件加入主机名&#xff08;全部节点&#xff09; cat /etc/hosts 192.168.88.5 master1 192.168.88.6 master2 192.168.88.7 master3 192.168.88.8 node13、关闭防火墙&#xff08;全部…

泥石流灾害风险评估与模拟丨AI与R语言、ArcGIS、HECRAS融合,提升泥石流灾害风险预测的精度和准确性

目录 第一章 理论基础 第二章 泥石流风险评估工具 第三章 数据准备与因子提取 第四章 泥石流灾害评价 第五章 HECRAS软件的应用 第六章 操作注意事项与模型优化 泥石流灾害的频发与严重后果&#xff0c;已成为全球范围内防灾减灾工作的重大挑战。随着科技的不断进步&…

自由学习记录(25)

只要有修改&#xff0c;子表就不用元表的参数了&#xff0c;用自己的参数&#xff08;只不过和元表里的那个同名&#xff09; 子表用__index“继承”了父表的值&#xff0c;此时子表仍然是空表 一定是创建这样一个同名的变量在原本空空的子表里&#xff0c; 传参要传具体的变…