部分代码:
//当前角度
int mAngleNum = 0;
//当前是正向旋转还是反向旋转
char mFront = 0;
//设置舵机当前的角度
mServo.write(180 - mAngleNum);
if( mFront == 0 )
{
mAngleNum ++;
if( mAngleNum > 180 )
{
mFront = 1;
}
}
else
{
mAngleNum --;
if( mAngleNum < 0 )
{
mFront = 0;
}
}
这里。实现了从 180度开始。每次减少1度。直到0度。然后开始从0度往180度增加。每次增加1度。
然后接下来。我们就需要 在每次舵机旋转的时候。我们进行超声波测距。
//当前距离
int mDistance = 0;
//超声波测距引脚
const int mTrigPin = 2;
const int mEchoPin = 3;
pinMode(mTrigPin, OUTPUT);
// 要检测引脚上输入的脉冲宽度,需要先设置为输入状态
pinMode(mEchoPin, INPUT);
// 产生一个10us的高脉冲
digitalWrite(mTrigPin, LOW);
delayMicroseconds(2);
digitalWrite(mTrigPin, HIGH);
delayMicroseconds(10);
digitalWrite(mTrigPin, LOW);
mDistance = pulseIn(mEchoPin, HIGH) / 58.0; //将回波时间换算成cm
这里。我们就是测试当前的距离。然后同时每次改变角度。都测试一次当前距离。我们每次改变角度、测试距离之后。都把我们的当前角度和距离。送给processing 让processing知道我们的当前状态。然后。processing 方面。我们需要一直不停的接受 arduino传递过来的当前硬件的状态数据(就是当前的角度和当前前方的距离)我这里设计的是。只测试前方180度的1.5m范围内的障碍物。好了。我们继续。我们在processing中。一直去查找数据。每次找到数据后。都把数据进行组装以及拆分。原因就是。我们传递的数据比较多。不是单一的数据。所以我们要区分我们具体每个数据。同时还要区分。多个数据的连续和间断问题。就是如何去读取和解析一个完整的数据包(包含当前角度和当前距离的一段数据) 首先我们需要在draw()里 每次都要读取数据。当然这里每次读取的都是一个int类型的数据。其实他是一个byte或者说是一个字节。也就是8个二进制 也同样是一个C语言里的char 还同样是一个ASCII 当然关于是否是unsigned之类的就先不说了。我们只要知道read()一次 读取出来的是个8个二进制位表示出来的数据 就够了。当然他是用int类型来存放的
if ( myPort.available() > 0) {
val = myPort.read(); }。我们这里没有真的用数据包的方式去处理的。而是用每次read之后。我把数据存放在181个int的数组中。因为角度是从0到180度。有181个数据.....然后。在draw() 中。每次都清空画布。然后重新绘制背景、然后绘制当前扫描效果的扇形。然后绘制当前的障碍物。画布设置:int mWidth = 600;
int mHeight = 300;
设置300的原因是方便计算。我准备扫描1.5米以内的同时180度的范围。所以可以设置成 宽度 1.5m * 2 = 150cm * 2 = 300cm, 高度1.5m = 150cm 。也可以设置成这个数据的一倍。就是 600cm, 300cm 或者两倍。三倍。由于屏幕宽度高度的原因。我就设置成了600,300。然后,我们每次绘制出来画布。就开始根据当前角度。来绘制一个半透明的内部填充的扇形。我吧当前角度 放到了扇形的中间。最后。根据181个int的数组。吧181个角度的障碍物的距离。绘制到屏幕上。当然 超出100cm或者少于5cm的都没有绘制。当然大家也可以自己回去改成 150cm 10cm之类的。
下面发一下绘制障碍物的具体代码:
Y~@MA3@]21_TG0[C3SQDV`X.png (25.39 KB, 下载次数: 161)
C]_G{P[4@C1UVUNAQB6$6BJ.png (25.56 KB, 下载次数: 97)
欢迎光临 (http://www.51hei.com/bbs/) | Powered by Discuz! X3.1 |