📄 catching.cpp
字号:
// Catching.cpp: implementation of the CCatching class.
//
//////////////////////////////////////////////////////////////////////
#include "stdafx.h"
#include "Catching.h"
#include "VoyPID.h"
#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
CCatching::CCatching()
{
m_BehShow = NULL;
m_ClrShow = NULL;
m_poverlookfind = NULL;
m_para.ReSet();
m_para.Ven = TRUE;
m_para.Vmin = 200;
m_para.Vmax = 1270;
m_CV.SetParam(&m_para);
}
CCatching::~CCatching()
{
}
struct SSPID vPID,wPID;
void CCatching::AfterUpdateVideoSample(BYTE *pBuffer, long lWidth, long lHeight, double dbTime, UINT nState)
{
//摄像头图像祯更新
m_CV.ImageBuf(lWidth,lHeight,pBuffer);
m_CV.FindSplash(TRUE);
if (m_para.Ysum == 0 && m_para.Usum == 0 && m_para.Vsum == 0)
{ //针对某些线程阻塞的情况
m_para.bBusy = FALSE;
}
static unsigned char StartFlag = false;
struct SSPID *v_PID = &vPID;
struct SSPID *w_PID = &wPID;
if(StartFlag == false)
{
///
v_PID->si_Ref = 35; //位置PID,位移设定值
v_PID->si_FeedBack = 0; //位置PID,位移反馈值,当前位置
v_PID->si_PreError = 0; //位置PID,前一次,位移误差,ui_Ref - FeedBack
v_PID->si_PreIntegral = 0; //位置PID,前一次,位移积分项,ui_PreIntegral+ui
v_PID->si_Kp = 5000; //位置PID,比例系数
v_PID->si_Ki = 500; //位置PID,积分系数
v_PID->si_Kd = 0; //位置PID,微分系数
v_PID->SS_MAX = 3000<<10; //输出上限,使控制信号扩大,以使过渡平顺
v_PID->SS_MIN = -3000<<10; //输出下限,
v_PID->SS_Imax = 20000; //积分饱和上限
v_PID ->SS_Imin = -20000; //积分饱和下限
v_PID->PLUS_DEADLINE = 5; //偏差死限的上限
v_PID->MINUS_DEADLINE = -5; //偏差死限的下限
v_PID->si_Accel = 0; //位置PID,加速度
v_PID->si_Speed = 0; //位置PID,最大速度
v_PID->ul_PreU = 0; //电机控制输出值
///
w_PID->si_Ref = 0; //位置PID,位移设定值
w_PID->si_FeedBack = 0; //位置PID,位移反馈值,当前位置
w_PID->si_PreError = 0; //位置PID,前一次,位移误差,ui_Ref - FeedBack
w_PID->si_PreIntegral = 0; //位置PID,前一次,位移积分项,ui_PreIntegral+ui
w_PID->si_Kp = 6000; //位置PID,比例系数
w_PID->si_Ki = 400; //位置PID,积分系数
w_PID->si_Kd = 0; //位置PID,微分系数
w_PID->SS_MAX = 1500<<10; //输出上限,使控制信号扩大,以使过渡平顺
w_PID->SS_MIN = -1500<<10; //输出下限,
w_PID->SS_Imax = 10000; //积分饱和上限
w_PID ->SS_Imin = -10000; //积分饱和下限
w_PID->PLUS_DEADLINE = 3; //偏差死限的上限
w_PID->MINUS_DEADLINE = -3; //偏差死限的下限
w_PID->si_Accel = 0; //位置PID,加速度
w_PID->si_Speed = 0; //位置PID,最大速度
w_PID->ul_PreU = 0; //电机控制输出值
StartFlag = true;
}
//像素数判断视频情况
if (m_para.Vsum < 1000)
{
m_strShow.Format("前方视距范围内丢失目标……");
output(&m_strShow,m_BehShow);
if (m_poverlookfind == NULL)
{
m_pCmd->Brake(1);
}
else
{
m_pCmd->SetBehavior(m_poverlookfind);
}
return;
}
v_PID->si_FeedBack = m_para.Vy;
if(m_para.Vy < 50)
{
w_PID->si_FeedBack = m_para.Vx;
w_PID->si_FeedBack = 160 - w_PID->si_FeedBack;
}
else
{
w_PID->si_FeedBack = m_para.Vx;
w_PID->si_FeedBack = 160 - w_PID->si_FeedBack;
w_PID->si_FeedBack *= 50;
w_PID->si_FeedBack /= m_para.Vy;
}
signed int TempSpeedV=0,TempSpeedW=0;
TempSpeedV = SSPIDCalc( v_PID );
TempSpeedV = 0 - TempSpeedV;
TempSpeedW = SSPIDCalc( w_PID );
m_pCmd->SetBothMotorsSpeed(TempSpeedV+TempSpeedW,TempSpeedV-TempSpeedW);
m_strShow.Format("(%d,%d):%d: %d,%d",m_para.Vx,m_para.Vy,m_para.Vsum,TempSpeedV,TempSpeedW);
output(&m_strShow,m_ClrShow);
/*
//对准球后靠近
if (m_para.Vx < 200 && m_para.Vx >120)
{
if (m_para.Vy < 10)
{
m_pCmd->Brake(1);
}
else
{
m_pCmd->SetBothMotorsSpeed(m_para.Vy*5,m_para.Vy*5);
}
return;
}
//没对准球则先对准球先对准球
if (m_para.Vx<160)
{
m_pCmd->SetBothMotorsSpeed(-150,150);
}
else
{
m_pCmd->SetBothMotorsSpeed(150,-150);
}
*/
}
void CCatching::output(CString *strShow, CListBox *inList)
{
if (inList != NULL)
{
inList->AddString(*strShow);
inList->SetCurSel(m_BehShow->GetCount()-1);
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -