需要源码请点赞关注收藏后评论区留言私信~~~~
当今社会正在步入一个万物互联的时代,它的技术基石主要来自5G、物联网和人工智能。 三者融合产生了许多新产品,其中最璀璨的当数自动驾驶的电动车;它汇聚了最新科技与工程实践的成果,引得各大巨头如华为、小米、百度、阿里、腾讯纷纷入场造车。 为啥这些科技巨头如此热衷造车呢?一个重要原因是智能车与移动互联密切相关,智能电动车与传统汽油车之间,犹如智能手机与功能手机的区别,可想而知,这是一个多么具有颠覆性的革命技术了。
为了实现自动行驶,智能小车必须具备下列功能方可正常工作:
(1)自动在符合要求的道路上开行;
(2)如果遇到障碍物,要能主动避让防止碰撞;
(3)服从命令听指挥,能够接收外部指令改变行驶状态;
小车组装效果如下 读者可自行前往淘宝等平台购买 本次选择的是51单片机小车

1)红外循迹模块 循迹模块采用红外反射传感器,检查路面对红外线的反射率是否在目标阈值之内。
该模块通过检测小车下方的路面颜色决定行进路线,检测方案采用红外反射传感器,检查路面对红外线的反射率是否在目标阈值内,反射距离范围为2毫米到30毫米
(2)红外避障模块 避障模块检测小车前方是否有障碍物,决定是否需要改变路线以躲避障碍。
该模块与红外迅疾地原理类似,通过检测小车前方是否有障碍物决定是否需要改变路线以及躲避障碍
(3)蓝牙遥控模块 操纵者使用手机向小车发送蓝牙信号,小车接到蓝牙信号后,依据指令调整行驶状态。
小车连接遥控模块之后,操纵者使用手机向小车发送蓝牙信号,小车接到蓝牙信号后,依据指令调整行驶状态。本次通过Wireshark抓取两部BLE设备之间的通信包
成功连接手机

可以在手机上行操纵电机的马力实现加速或者减速

实物演示效果如下

部分代码如下 需要全部源码请点赞关注收藏后评论区留言~~~~
package com.example.iot;
import androidx.appcompat.app.AppCompatActivity;
import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothManager;
import android.bluetooth.le.BluetoothLeScanner;
import android.bluetooth.le.ScanCallback;
import android.bluetooth.le.ScanResult;
import android.content.Context;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.os.Bundle;
import android.os.Handler;
import android.os.Looper;
import android.text.TextUtils;
import android.util.Log;
import android.widget.CheckBox;
import android.widget.CompoundButton;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import com.example.iot.adapter.BlueListAdapter;
import com.example.iot.bean.BlueDevice;
import com.example.iot.util.BluetoothUtil;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class ScanCarActivity extends AppCompatActivity implements CompoundButton.OnCheckedChangeListener {
private static final String TAG = "ScanCarActivity";
private CheckBox ck_bluetooth; // 声明一个复选框对象
private TextView tv_discovery; // 声明一个文本视图对象
private ListView lv_bluetooth; // 声明一个用于展示蓝牙设备的列表视图对象
private BlueListAdapter mListAdapter; // 声明一个蓝牙设备的列表适配器对象
private Map<String, BlueDevice> mDeviceMap = new HashMap<>(); // 蓝牙设备映射
private List<BlueDevice> mDeviceList = new ArrayList<>(); // 蓝牙设备列表
private Handler mHandler = new Handler(Looper.myLooper()); // 声明一个处理器对象
private BluetoothAdapter mBluetoothAdapter; // 声明一个蓝牙适配器对象
private boolean isScaning = false; // 是否正在扫描
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_scan_car);
initView(); // 初始化视图
initBluetooth(); // 初始化蓝牙适配器
if (BluetoothUtil.getBlueToothStatus()) { // 已经打开蓝牙
ck_bluetooth.setChecked(true);
}
}
// 初始化视图
private void initView() {
ck_bluetooth = findViewById(R.id.ck_bluetooth);
tv_discovery = findViewById(R.id.tv_discovery);
lv_bluetooth = findViewById(R.id.lv_bluetooth);
ck_bluetooth.setOnCheckedChangeListener(this);
mListAdapter = new BlueListAdapter(this, mDeviceList);
lv_bluetooth.setAdapter(mListAdapter);
lv_bluetooth.setOnItemClickListener((parent, view, position, id) -> {
BlueDevice item = mDeviceList.get(position);
Intent intent = new Intent(this, SmartCarActivity.class);
intent.putExtra("address", item.address);
startActivity(intent);
});
}
// 初始化蓝牙适配器
private void initBluetooth() {
if (!getPackageManager().hasSystemFeature(PackageManager.FEATURE_BLUETOOTH_LE)) {
Toast.makeText(this, "当前设备不支持低功耗蓝牙", Toast.LENGTH_SHORT).show();
finish(); // 关闭当前页面
}
// 获取蓝牙管理器,并从中得到蓝牙适配器
BluetoothManager bm = (BluetoothManager) getSystemService(Context.BLUETOOTH_SERVICE);
mBluetoothAdapter = bm.getAdapter(); // 获取蓝牙适配器
}
// 创建一个开启BLE扫描的任务
private Runnable mScanStart = new Runnable() {
@Override
public void run() {
if (!isScaning && BluetoothUtil.getBlueToothStatus()) {
isScaning = true;
// 获取BLE设备扫描器
BluetoothLeScanner scanner = mBluetoothAdapter.getBluetoothLeScanner();
scanner.startScan(mScanCallback); // 开始扫描BLE设备
tv_discovery.setText("点击BLE设备进入管理界面");
} else {
mHandler.postDelayed(this, 2000);
}
}
};
// 创建一个扫描回调对象
private ScanCallback mScanCallback = new ScanCallback() {
@Override
public void onScanResult(int callbackType, ScanResult result) {
super.onScanResult(callbackType, result);
if (TextUtils.isEmpty(result.getDevice().getName())) {
return;
}
Log.d(TAG, "callbackType="+callbackType+", result="+result.toString());
// 下面把找到的蓝牙设备添加到设备映射和设备列表
BlueDevice device = new BlueDevice(result.getDevice().getName(), result.getDevice().getAddress(), 0);
mDeviceMap.put(device.address, device);
mDeviceList.clear();
mDeviceList.addAll(mDeviceMap.values());
runOnUiThread(() -> mListAdapter.notifyDataSetChanged());
}
@Override
public void onBatchScanResults(List<ScanResult> results) {
super.onBatchScanResults(results);
}
@Override
public void onScanFailed(int errorCode) {
super.onScanFailed(errorCode);
}
};
// 创建一个停止BLE扫描的任务
private Runnable mScanStop = () -> {
isScaning = false;
// 获取BLE设备扫描器
BluetoothLeScanner scanner = mBluetoothAdapter.getBluetoothLeScanner();
scanner.stopScan(mScanCallback); // 停止扫描BLE设备
};
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
if (buttonView.getId() == R.id.ck_bluetooth) {
if (isChecked) { // 开启蓝牙功能
ck_bluetooth.setText("蓝牙开");
if (!BluetoothUtil.getBlueToothStatus()) { // 还未打开蓝牙
BluetoothUtil.setBlueToothStatus(true); // 开启蓝牙功能
}
mHandler.post(mScanStart); // 启动开始BLE扫描的任务
} else { // 关闭蓝牙功能
ck_bluetooth.setText("蓝牙关");
mHandler.removeCallbacks(mScanStart); // 移除开始BLE扫描的任务
BluetoothUtil.setBlueToothStatus(false); // 关闭蓝牙功能
mDeviceList.clear();
mListAdapter.notifyDataSetChanged();
}
}
}
@Override
protected void onDestroy() {
super.onDestroy();
mHandler.removeCallbacks(mScanStart); // 移除开始BLE扫描的任务
mHandler.removeCallbacks(mScanStop); // 移除停止BLE扫描的任务
}
}
创作不易 觉得有帮助请点赞关注收藏~~~
一、引擎主循环UE版本:4.27一、引擎主循环的位置:Launch.cpp:GuardedMain函数二、、GuardedMain函数执行逻辑:1、EnginePreInit:加载大多数模块int32ErrorLevel=EnginePreInit(CmdLine);PreInit模块加载顺序:模块加载过程:(1)注册模块中定义的UObject,同时为每个类构造一个类默认对象(CDO,记录类的默认状态,作为模板用于子类实例创建)(2)调用模块的StartUpModule方法2、FEngineLoop::Init()1、检查Engine的配置文件找出使用了哪一个GameEngine类(UGame
@作者:SYFStrive @博客首页:HomePage📜:微信小程序📌:个人社区(欢迎大佬们加入)👉:社区链接🔗📌:觉得文章不错可以点点关注👉:专栏连接🔗💃:感谢支持,学累了可以先看小段由小胖给大家带来的街舞👉微信小程序(🔥)目录自定义组件-behaviors 1、什么是behaviors 2、behaviors的工作方式 3、创建behavior 4、导入并使用behavior 5、behavior中所有可用的节点 6、同名字段的覆盖和组合规则总结最后自定义组件-behaviors 1、什么是behaviorsbehaviors是小程序中,用于实现
在他们的网站上找不到任何内容。我主要只是想看看哪个值得一试(当然是RIA)。谢谢 最佳答案 SproutCoredemos 关于ruby-是否有SproutCore或Cappuccino的现场演示/示例应用程序,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1419788/
前面一篇关于智能合约翻译文讲到了,是一种计算机程序,既然是程序,那就可以使用程序语言去编写智能合约了。而若想玩区块链上的项目,大部分区块链项目都是开源的,能看得懂智能合约代码,或找出其中的漏洞,那么,学习Solidity这门高级的智能合约语言是有必要的,当然,这都得在公链``````以太坊上,毕竟国内的联盟链有些是不兼容Solidity。Solidity是一种面向对象的高级语言,用于实现智能合约。智能合约是管理以太坊状态下的账户行为的程序。Solidity是运行在以太坊(Ethereum)虚拟机(EVM)上,其语法受到了c++、python、javascript影响。Solidity是静态类型
1.回顾.TransportServicepublicclassTransportServiceextendsAbstractLifecycleComponentTransportService:方法:1publicfinalTextendsTransportResponse>voidsendRequest(finalTransport.Connectionconnection,finalStringaction,finalTransportRequestrequest,finalTransportRequestOptionsoptions,TransportResponseHandlerT>
一、什么是MQTT协议MessageQueuingTelemetryTransport:消息队列遥测传输协议。是一种基于客户端-服务端的发布/订阅模式。与HTTP一样,基于TCP/IP协议之上的通讯协议,提供有序、无损、双向连接,由IBM(蓝色巨人)发布。原理:(1)MQTT协议身份和消息格式有三种身份:发布者(Publish)、代理(Broker)(服务器)、订阅者(Subscribe)。其中,消息的发布者和订阅者都是客户端,消息代理是服务器,消息发布者可以同时是订阅者。MQTT传输的消息分为:主题(Topic)和负载(payload)两部分Topic,可以理解为消息的类型,订阅者订阅(Su
参考文章搭建文章gitte源码在线体验可以注册两个号来测试演示图:一.整体介绍 介绍SignalR一种通讯模型Hub(中心模型,或者叫集线器模型),调用这个模型写好的方法,去发送消息。 内容有: ①:Hub模型的方法介绍 ②:服务器端代码介绍 ③:前端vue3安装并调用后端方法 ④:聊天室样例整体流程:1、进入网站->调用连接SignalR的方法2、与好友发送消息->调用SignalR的自定义方法 前端通过,signalR内置方法.invoke() 去请求接口3、监听接受方法(渲染消息)通过new signalR.HubConnectionBuilder().on
2022年底,OpenAI的预训练模型ChatGPT给人工智能领域的爱好者和研究人员留下了深刻的印象和启发,他展现的惊人能力将人工智能的研究和应用热度推向高潮,网上也充斥着和ChatGPT的各种聊天,他可以作诗、写小说、写代码、讨论疫情问题等。下面就是一些他的神回复:人命关天的坑: 写歌,留给词作者的机会不多了。。。 回答人类怎么样面对人工智能: 什么是ChatGPT?借用网上的一段介绍,ChatGPT是由人工智能研究实验室OpenAI在2022年11月30日发布的全新聊天机器人模型,一款人工智能技术驱动的自然语言处理工具。它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动
如何使用Capistrano将Rails应用程序部署到无法访问外部网络或存储库的生产或暂存服务器?我已经设法完成部署的一半,并意识到Capistrano没有在我的本地机器上下载gitrepo,但它首先连接到远程服务器并尝试在那里下载Git存储库。我希望有一个类似Javaee的构建系统,其中创建可交付成果并将该可交付成果发送到服务器。就像您构建.ear文件并将其部署到您想要的任何服务器上一样。显然在RoR中,你被迫(据我所知)在该服务器上构建应用程序,在那里创建一个gem存储库,在那里克隆最新的分支等等。有什么方法可以将准备运行的包发送到远程服务器吗? 最佳答
我一直在使用zeroMQ,我希望能够通过Internet安全连接。我在ruby中,可以使用SSL和/或某种shh连接,但找不到有关如何执行此操作的任何示例。我找到了这个旧的stackoverflow链接,HowdoeszeromqworktogetherwithSSL?说他们正在研究某种安全性,但那是一年前的事了,我找不到任何新的引用资料。即使这不是内置在zeroMQ中,我也假设会有一些方法可以使用OpenSSL或类似的东西来设置它。注意:如果您想要安全传输,zeroMQ网站提到使用VPN或其他东西。我不想使用VPN。一定有更好的方法。 最佳答案