91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何制作Arduino雷達(dá)

454398 ? 來源:wv ? 2019-08-28 11:06 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

第1步:材料和程序

此構(gòu)建所需的材料包括:

- 1個伺服

- 1個超聲波傳感器

- 1個蜂鳴器

- 1面包板

- 1 UNO R3 Arduino

- 電線堆

制作此雷達(dá)所需的程序:

- Arduino IDE

- 處理3.4

要將上述程序下載到您的計(jì)算機(jī)上,請點(diǎn)擊以下鏈接:

- https://www.arduino.cc/en/main/software

-https://processing.org/download/

第2步:Arduino代碼

這是arduino代碼,它基本上控制伺服和傳感器的運(yùn)動和輸入。這是從youtube視頻https://www.youtube.com/watch?v=JvmIutmQd9U復(fù)制而來,似乎與我的arduino板和計(jì)算機(jī)很好地配合。

// Includes the servo library

#include 。

// Defines Trig and Echo pins of the Ultrasonic Sensor

const int trigPin = 10;

const int echoPin = 11;

#define buzzerPin A0 //Defines the pin A0 as an output to buzzerPin

// Variables for the duration and the distance

long duration;

int distance;

Servo myServo; // Creates a servo object for controlling the servo motor

void setup() {

pinMode(trigPin, OUTPUT); // Sets the trigPin as an Output

pinMode(echoPin, INPUT); // Sets the echoPin as an Input

Serial.begin(9600);

myServo.attach(12); // Defines on which pin is the servo motor attached

}

void loop() {

// rotates the servo motor from 15 to 165 degrees

for(int i=15;i《=165;i++){

myServo.write(i);

delay(30);

distance = calculateDistance();// Calls a function for calculating the distance measured by the Ultrasonic sensor for each degree

Serial.print(i); // Sends the current degree into the Serial Port

Serial.print(“,”); // Sends addition character right next to the previous value needed later in the Processing IDE for indexing

Serial.print(distance); // Sends the distance value into the Serial Port

Serial.print(“?!保? // Sends addition character right next to the previous value needed later in the Processing IDE for indexing

tone(buzzerPin, 10000 / distance);

}

// Repeats the previous lines from 165 to 15 degrees

for(int i=165;i》15;i--){

myServo.write(i);

delay(30);

distance = calculateDistance();

Serial.print(i);

Serial.print(“,”);

Serial.print(distance);

Serial.print(“?!保?

tone(buzzerPin, 10000 / distance); //Produces a different tone according to the distance the object is from the sensor

}

}

// Function for calculating the distance measured by the Ultrasonic sensor

int calculateDistance(){

digitalWrite(trigPin, LOW);

delayMicroseconds(2);

// Sets the trigPin on HIGH state for 10 micro seconds

digitalWrite(trigPin, HIGH);

delayMicroseconds(10);

digitalWrite(trigPin, LOW);

duration = pulseIn(echoPin, HIGH); // Reads the echoPin, returns the sound wave travel time in microseconds

distance= duration*0.034/2;

return distance;

}

步驟3:處理代碼

以下是我用于處理程序從超聲波傳感器獲取信息的代碼,并將其轉(zhuǎn)換為它創(chuàng)建的顯示。這是我從視頻https://www.youtube.com/watch?v=JvmIutmQd9U復(fù)制的代碼,該代碼效果非常好,只需要進(jìn)行一些調(diào)整。

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px ‘Helvetica Neue’; color: #000000; -webkit-text-stroke: #000000}

p.p2 {margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px ‘Helvetica Neue’; color: #000000; -webkit-text-stroke: #000000; min-height: 12.0px}

span.s1 {font-kerning: none}

import processing.serial.*; // imports library for serial communication

import java.awt.event.KeyEvent; // imports library for reading the data from the serial port

import java.io.IOException;

Serial myPort; // defines Object Serial

// defubes variables

String angle=“”;

String distance=“”;

String data=“”;

String noObject;

float pixsDistance;

int iAngle, iDistance;

int index1=0;

int index2=0;

PFont orcFont;

void setup() {

size (1200, 700); // ***CHANGE THIS TO YOUR SCREEN RESOLUTION***

smooth();

myPort = new Serial(this,“/dev/cu.usbmodem143401”, 9600); // starts the serial communication

myPort.bufferUntil(‘?!? // reads the data from the serial port up to the character ‘?!? So actually it reads this: angle,distance.

}

void draw() {

fill(98,245,31);

// simulating motion blur and slow fade of the moving line

noStroke();

fill(0,4);

rect(0, 0, width, height-height*0.065);

fill(98,245,31); // green color

// calls the functions for drawing the radar

drawRadar();

drawLine();

drawObject();

drawText();

}

void serialEvent (Serial myPort) { // starts reading data from the Serial Port

// reads the data from the Serial Port up to the character ‘?!?and puts it into the String variable “data”。

data = myPort.readStringUntil(‘?!?

data = data.substring(0,data.length()-1);

index1 = data.indexOf(“,”); // find the character ‘,’ and puts it into the variable “index1”

angle= data.substring(0, index1); // read the data from position “0” to position of the variable index1 or thats the value of the angle the Arduino Board sent into the Serial Port

distance= data.substring(index1+1, data.length()); // read the data from position “index1” to the end of the data pr thats the value of the distance

// converts the String variables into Integer

iAngle = int(angle);

iDistance = int(distance);

}

void drawRadar() {

pushMatrix();

translate(width/2,height-height*0.074); // moves the starting coordinats to new location

noFill();

strokeWeight(2);

stroke(98,245,31);

// draws the arc lines

arc(0,0,(width-width*0.0625),(width-width*0.0625),PI,TWO_PI);

arc(0,0,(width-width*0.27),(width-width*0.27),PI,TWO_PI);

arc(0,0,(width-width*0.479),(width-width*0.479),PI,TWO_PI);

arc(0,0,(width-width*0.687),(width-width*0.687),PI,TWO_PI);

// draws the angle lines

line(-width/2,0,width/2,0);

line(0,0,(-width/2)*cos(radians(30)),(-width/2)*sin(radians(30)));

line(0,0,(-width/2)*cos(radians(60)),(-width/2)*sin(radians(60)));

line(0,0,(-width/2)*cos(radians(90)),(-width/2)*sin(radians(90)));

line(0,0,(-width/2)*cos(radians(120)),(-width/2)*sin(radians(120)));

line(0,0,(-width/2)*cos(radians(150)),(-width/2)*sin(radians(150)));

line((-width/2)*cos(radians(30)),0,width/2,0);

popMatrix();

}

void drawObject() {

pushMatrix();

translate(width/2,height-height*0.074); // moves the starting coordinats to new location

strokeWeight(9);

stroke(255,10,10); // red color

pixsDistance = iDistance*((height-height*0.1666)*0.025); // covers the distance from the sensor from cm to pixels

// limiting the range to 40 cms

if(iDistance《40){

// draws the object according to the angle and the distance

line(pixsDistance*cos(radians(iAngle)),-pixsDistance*sin(radians(iAngle)),(width-width*0.505)*cos(radians(iAngle)),-(width-width*0.505)*sin(radians(iAngle)));

}

popMatrix();

}

void drawLine() {

pushMatrix();

strokeWeight(9);

stroke(30,250,60);

translate(width/2,height-height*0.074); // moves the starting coordinats to new location

line(0,0,(height-height*0.12)*cos(radians(iAngle)),-(height-height*0.12)*sin(radians(iAngle))); // draws the line according to the angle

popMatrix();

}

void drawText() { // draws the texts on the screen

pushMatrix();

if(iDistance》40) {

noObject = “Out of Range”;

}

else {

noObject = “In Range”;

}

fill(0,0,0);

noStroke();

rect(0, height-height*0.0648, width, height);

fill(98,245,31);

textSize(25);

text(“10cm”,width-width*0.3854,height-height*0.0833);

text(“20cm”,width-width*0.281,height-height*0.0833);

text(“30cm”,width-width*0.177,height-height*0.0833);

text(“40cm”,width-width*0.0729,height-height*0.0833);

textSize(40);

text(“Ryan‘s Radar”, width-width*0.875, height-height*0.0277);

text(“Angle: ” + iAngle +“ °”, width-width*0.48, height-height*0.0277);

text(“Distance: ”, width-width*0.26, height-height*0.0277);

if(iDistance《40) {

text(“ ” + iDistance +“ cm”, width-width*0.225, height-height*0.0277);

}

textSize(25);

fill(98,245,60);

translate((width-width*0.4994)+width/2*cos(radians(30)),(height-height*0.0907)-width/2*sin(radians(30)));

rotate(-radians(-60));

text(“30°”,0,0);

resetMatrix();

translate((width-width*0.503)+width/2*cos(radians(60)),(height-height*0.0888)-width/2*sin(radians(60)));

rotate(-radians(-30));

text(“60°”,0,0);

resetMatrix();

translate((width-width*0.507)+width/2*cos(radians(90)),(height-height*0.0833)-width/2*sin(radians(90)));

rotate(radians(0));

text(“90°”,0,0);

resetMatrix();

translate(width-width*0.513+width/2*cos(radians(120)),(height-height*0.07129)-width/2*sin(radians(120)));

rotate(radians(-30));

text(“120°”,0,0);

resetMatrix();

translate((width-width*0.5104)+width/2*cos(radians(150)),(height-height*0.0574)-width/2*sin(radians(150)));

rotate(radians(-60));

text(“150°”,0,0);

popMatrix();

}

步驟4:超聲波傳感器支架

由于我對此項(xiàng)目的啟發(fā)并未包含任何類型的支架來固定超聲波傳感器在適當(dāng)?shù)奈恢?,我決定3D打印這個支架是一個好主意,讓完成的設(shè)計(jì)看起來更整潔,并使一切更容易組合。保持超聲波傳感器的部分最終相對緊密地安裝在超聲波傳感器周圍,在保持其就位方面做得很好。然而,在下面切出的用于伺服臂進(jìn)入的孔有點(diǎn)太大,所以我需要添加很多膠水來保持它的位置。但總的來說,它的效果非常好,并且設(shè)計(jì)看起來很漂亮。

第5步:激光切割盒設(shè)計(jì)

實(shí)施此框以使項(xiàng)目具有干凈和專業(yè)的外觀。它在隱藏所有電線和arduino板本身方面做得很好。為了創(chuàng)建實(shí)際的盒子設(shè)計(jì),我使用網(wǎng)站http://www.makercase.com/來獲得手指邊緣以將盒子的每一側(cè)連接在一起。這是一個非常有用的網(wǎng)站,因?yàn)樗?jié)省了我大量的時間,并且非常容易使用。從雷達(dá)的成品中可以看出,我在設(shè)計(jì)的側(cè)面和頂部切出了測量孔,以便允許項(xiàng)目的部分需要在外面。這包括用于伺服的孔,我從下面粘到盒子上,連接到超聲波傳感器,蜂鳴器,以及從計(jì)算機(jī)到arduino板本身。這是相當(dāng)大的(盒子里有很多空間),但至少它給你很大的工作空間,沒有任何東西是狹窄的。如果你自己做一個盒子設(shè)計(jì),你肯定可以做得更小,一切都會適合。

步驟6:接線構(gòu)造

根據(jù)arduino代碼,超聲波傳感器必須連接到引腳10 11.雖然和所有超聲波傳感器一樣,它也必須連接到地和5V引腳。伺服必須連接到引腳12(myServo.attach(12);),它還必須連接到地和5V引腳。至于蜂鳴器,它只接地和模擬輸出引腳A0。一旦你為雷達(dá)附加了所有必要的物品,你的電路應(yīng)該看起來有點(diǎn)像上圖。此外,盡量保持一切整潔!一旦電路在盒子里,電線都非常纏結(jié),有可能一根或兩根電線滑出不到位置并導(dǎo)致雷達(dá)發(fā)生故障。它發(fā)生在我身上,我發(fā)現(xiàn)它從那時起就保持整潔,減少了這些事件的發(fā)生。

步驟7:組裝

使用強(qiáng)力超級膠水組裝激光切割盒,因此完成后不會有碎片分開雷達(dá)。我發(fā)現(xiàn)更容易使用一些書來支撐盒子的一側(cè),這樣我就可以粘上相鄰的一面。在那里拿著它約5分鐘后,我會繼續(xù)到下一側(cè),依此類推。記住不要粘上其中一端,因?yàn)槟泔@然需要放入并取出雷達(dá)。一旦盒子上的膠水硬化,您就可以繼續(xù)裝配。首先,我將蜂鳴器粘在外殼的頂部(如上圖所示),然后當(dāng)它干燥時,我將電線穿過相對的孔并將它們連接到蜂鳴器上。當(dāng)談到伺服系統(tǒng)時,我將伺服的小翼粘在盒子下面,所以只有伺服的頂部顯示出來。這使得整個產(chǎn)品看起來既美觀又保持其實(shí)用性,伺服頭可隨時輕松訪問。然后使用3D打印支架中的超聲波傳感器,使用膠水將支架連接到伺服系統(tǒng),以確保其安全。完成后,您的項(xiàng)目即可進(jìn)行測試!

步驟8:執(zhí)行

首先將計(jì)算機(jī)連接到arduino板。接下來,打開兩個程序。加載arduino代碼后,將其上傳到主板。這應(yīng)該開始伺服和蜂鳴器,因此會產(chǎn)生噪音,伺服也會相應(yīng)轉(zhuǎn)動。然后,當(dāng)加載處理代碼時,單擊運(yùn)行,如果一切順利運(yùn)行,則應(yīng)顯示雷達(dá)的動畫。如果沒有發(fā)生這種情況,請檢查您使用的端口名稱是否與代碼中的名稱完全相同。例如,如果我使用端口“/dev/cu.usbmodem143401”,請確保處理中的代碼行顯示“myPort = new Serial(this,”/dev/cu.usbmodem143401“,9600);”。這應(yīng)該解決所有問題,它應(yīng)該運(yùn)行順利。啟動和運(yùn)行的過程都可以在上面的視頻鏈接上看到它正在工作和檢測對象。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 雷達(dá)
    +關(guān)注

    關(guān)注

    52

    文章

    3342

    瀏覽量

    124066
  • Arduino
    +關(guān)注

    關(guān)注

    190

    文章

    6526

    瀏覽量

    197083
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    Arduino plc和termux esp

    Arduino plc和termux esp
    的頭像 發(fā)表于 12-06 06:41 ?1903次閱讀

    定華雷達(dá)儀表學(xué)堂:雷達(dá)液位計(jì)有些什么好處?

    雷達(dá)液位計(jì)在不少小型工業(yè)場合中可能還不為人所熟悉,但在許多大型工業(yè)生產(chǎn)環(huán)境中,它已經(jīng)得到了廣泛應(yīng)用。雷達(dá)物位計(jì)具備諸多顯著優(yōu)勢。 首先,它具有出色的穿透能力。例如,空氣中存在的水蒸氣對許多同類儀表會
    的頭像 發(fā)表于 11-21 15:08 ?527次閱讀

    智能駕駛的“感官系統(tǒng)”:超聲波雷達(dá)、毫米波雷達(dá)與激光雷達(dá)的協(xié)同之道

    一套復(fù)雜的傳感器系統(tǒng)——其中,超聲波雷達(dá)、毫米波雷達(dá)和激光雷達(dá)構(gòu)成了智能駕駛的“感官三重奏”,各司其職、協(xié)同工作,共同構(gòu)建車輛對環(huán)境的全面認(rèn)知。 超聲波雷達(dá):最“接地氣”的近距離守護(hù)者
    的頭像 發(fā)表于 11-04 17:43 ?1276次閱讀
    智能駕駛的“感官系統(tǒng)”:超聲波<b class='flag-5'>雷達(dá)</b>、毫米波<b class='flag-5'>雷達(dá)</b>與激光<b class='flag-5'>雷達(dá)</b>的協(xié)同之道

    定華雷達(dá)儀表學(xué)堂:如何選擇雷達(dá)液位計(jì)?

    西安定華電子提醒大家,在雷達(dá)物位計(jì)選型的時候,要考慮攪拌、抽真空的影響,對電源和輸出信號也要注意。 ?1?有攪拌情況下選型 雷達(dá)液位計(jì)廠家認(rèn)為在有攪拌的罐體內(nèi),一般不要選用導(dǎo)波雷達(dá),攪拌所帶來的力量
    的頭像 發(fā)表于 10-30 16:57 ?664次閱讀

    微波雷達(dá)和毫米波雷達(dá)有什么區(qū)別

    微波雷達(dá)和毫米波雷達(dá)有什么區(qū)別 前言:不知道大家有沒有發(fā)現(xiàn),各種雷達(dá)模塊的使用開始逐漸加入各種智能家居產(chǎn)品了,像人來燈亮,人走燈滅這種雷達(dá)感應(yīng)的產(chǎn)品早幾年就開始進(jìn)入市場了,還有各種感應(yīng)
    的頭像 發(fā)表于 10-30 16:56 ?2108次閱讀
    微波<b class='flag-5'>雷達(dá)</b>和毫米波<b class='flag-5'>雷達(dá)</b>有什么區(qū)別

    定華雷達(dá)儀表學(xué)堂:如何區(qū)別高頻與低頻雷達(dá)物位計(jì)性能比較?

    按發(fā)射雷達(dá)波的頻率分,可分為高頻雷達(dá)和低頻雷達(dá)。高頻雷達(dá)發(fā)射的20GHz以上的高頻微波,根據(jù)波的特性:速度=波長*頻率,我們可以得知24GHz高頻的微波的波長較其他頻段的
    的頭像 發(fā)表于 10-17 15:27 ?438次閱讀

    如何用Arduino Nano/UNO R3開發(fā)板給另一個Arduino IDE不能下載的Arduino Nano/UNO R3開發(fā)板重新燒錄引導(dǎo)程序bootlaoder

    本文介紹了如何用能夠Arduino IDE下載的Arduino Nano/UNO R3開發(fā)板給另一個Arduino IDE不能下載的Arduino Nano/UNO R3開發(fā)板重新燒錄
    的頭像 發(fā)表于 08-08 20:16 ?3672次閱讀
    如何用<b class='flag-5'>Arduino</b> Nano/UNO R3開發(fā)板給另一個<b class='flag-5'>Arduino</b> IDE不能下載的<b class='flag-5'>Arduino</b> Nano/UNO R3開發(fā)板重新燒錄引導(dǎo)程序bootlaoder

    ?定華雷達(dá)儀表學(xué)堂:雷達(dá)物位計(jì)的安裝和基本調(diào)試步驟是怎樣的

    雷達(dá)物位計(jì)能否準(zhǔn)確丈量,依靠于反射波的信號。假如在所選擇安裝的位置,液面不能將電磁波反射回雷達(dá)天線或在信號波的范圍內(nèi)有干擾物反射干擾波給雷達(dá)物位計(jì),雷達(dá)物位計(jì)都不能準(zhǔn)確反映實(shí)際液位。因
    的頭像 發(fā)表于 07-21 14:10 ?450次閱讀

    雷達(dá)液位計(jì)的維護(hù)要求有哪些?

    雷達(dá)
    jzyb
    發(fā)布于 :2025年07月16日 13:15:22

    定華雷達(dá)儀表學(xué)堂:接觸式雷達(dá)液位計(jì)原理介紹

    接觸式雷達(dá)物位計(jì)用于液體和固體的物位測量。即使是在高壓和極端溫度下,他們也能測量各種介質(zhì)。雷達(dá)傳感器既可以用于簡單測量,也可以用于測量腐蝕性介質(zhì),對于衛(wèi)生要求跟高的場合同樣適用。這些傳感器能可靠
    的頭像 發(fā)表于 06-20 09:44 ?567次閱讀

    雷達(dá)水位站 非接觸式測量水位

    雷達(dá)
    pingao141378
    發(fā)布于 :2025年06月09日 14:21:17

    免費(fèi)分享Arduino入門+進(jìn)階(全套例程+書籍)

    Arduino是一款開源電子原型平臺,由硬件(單片機(jī)開發(fā)板)和軟件(編程環(huán)境)組成,旨在讓非專業(yè)用戶也能輕松入門電子制作和編程。它的核心思想是簡化硬件開發(fā),通過直觀的編程和模塊化設(shè)計(jì),讓用戶快速實(shí)現(xiàn)
    的頭像 發(fā)表于 05-22 11:40 ?1159次閱讀
    免費(fèi)分享<b class='flag-5'>Arduino</b>入門+進(jìn)階(全套例程+書籍)

    《ESP32S3 Arduino開發(fā)指南》第二章 Arduino基礎(chǔ)知識

    完成一個電子產(chǎn)品的制作。這就給開源硬件的推廣和普及設(shè)定了一個很高的門檻,電子愛好者需要花很多時間和精力才能開始開發(fā)和制作自己的作品。而使用Arduino能很快地完成一個電子產(chǎn)品的制作,
    發(fā)表于 05-13 09:28

    定華雷達(dá)儀表學(xué)堂:雷達(dá)物位計(jì)天線種類

    雷達(dá)物位計(jì)具有高精度、壽命長、低維護(hù)、高性能等優(yōu)點(diǎn)。應(yīng)用行業(yè)廣泛,可以在高溫、高壓、蒸汽、真空及高粉塵等惡劣環(huán)境中進(jìn)行連續(xù)測量。但是不同環(huán)境下選擇的雷達(dá)物位計(jì)型號不同,使用的天線也不相同。下面介紹
    的頭像 發(fā)表于 04-16 15:20 ?788次閱讀