由于项目需要,进行过一段时间的 PariticalFilter 研究。主要的工作就是将网络上的Console代码和Mfc融合在一起,并且添加了Mfc端的控制功能。

      程序还有不完善的地方,现将相关的函数发布出来,大家相互研究。程序运行界面
程序的核心为两个部分,一个是核心PF函数,一个是界面操作
核心函数
.
    #.
    #.
    #.
    #.
     );
     );
    sd  );    , histo );
    s  );
    v  );
    cvSplit( imgs, h, s, v, NULL );
        ; r ; c ;
        }
        cvReleaseImage( , inv_sum;
    ; i . ; i  );
    cvCopy( frame, tmp, NULL );
    cvResetImageROI( frame );
    histos  );
    normalize_histogram( histos );
    cvReleaseImage( ;
    particles ;
    y ;
    ; j .;
        particles[k].width ;
    }
    ;
    ;
        y ;
        particles[k].x0 .;
        particles[k].width ;
        i  ) .
    #.
    #.
    .
    #.
    #.0000
    ., MIN( (., x ) );
    y ., MIN( (., y ) );
    s . ) . ) .;
    pn.s ., s );
    pn.xp ;
    ;
  ; i . ;
    ;
    ;
}

    IplImage matimg(matSrc);
    IplImage, r , w, h ) );
    tmp  );
    cvCopy( img, tmp, NULL );
    cvResetImageROI( img );
    histo  );
    cvReleaseImage( ;
    ; i ; i ;
    ; i ; j ];
exit. . ,,));
}
界面处理相关
void CGOMfcTemplate2Dlg::OnMouseMove(UINT nFlags, CPoint point)
{
    CRect rect_ctr;  
    (this->GetDlgItem(IDC_CAM))->GetWindowRect(&rect_ctr);//获取Picture控件相对屏幕左上角的坐标,  
    ScreenToClient(rect_ctr);//获取Picture控件相对对话框客户区左上角的坐标  
    instant_position.x = point.x;
    instant_position.y = point.y;
    picture_ordinate_x = point.x - rect_ctr.left;
    picture_ordinate_y = point.y - rect_ctr.top;//point获取的是鼠标相对对话框客户区左上角的坐标,减去rect_ctr.left和rect_ctr.top后,即为鼠标相对Picture控件左上角的坐标  
    if ((nFlags == MK_LBUTTON) && Is_LeftButton_Down)
    {
        ::SetCursor(cross);
        CClientDC dc(this);
        CBrush *OldBrush;
        OldBrush=(CBrush*)dc.SelectStockObject(NULL_BRUSH);
        dc.SetROP2(R2_NOT);
        dc.Rectangle(CRect(chosen_position,instant_position));
        dc.Rectangle(CRect(chosen_position,point));
        dc.SelectObject(OldBrush);
        instant_position=point;
    }
    else
        ::SetCursor(arrow);
    CDialogEx::OnMouseMove(nFlags, point);
}

void CGOMfcTemplate2Dlg::OnLButtonDown(UINT nFlags, CPoint point)
{
    Is_LeftButton_Down = true;
    ::SetCursor(cross);
    chosen_position = instant_position = point;
    CDialogEx::OnLButtonDown(nFlags, point);
}
void CGOMfcTemplate2Dlg::OnLButtonUp(UINT nFlags, CPoint point)
{
    if (Is_LeftButton_Down)
    {
        Is_LeftButton_Down = false;
        ::SetCursor(arrow);
        CClientDC dc(this);
        CPen* pOldPen=(CPen*)dc.SelectObject(&pen);
        dc.MoveTo(chosen_position);
        dc.LineTo(chosen_position.x,instant_position.y);
        dc.LineTo(instant_position);
        dc.LineTo(instant_position.x,chosen_position.y);
        dc.LineTo(chosen_position);
        //写到rect_res中区
        int rect_x = min(chosen_position.x,instant_position.x);
        int rect_y = min(chosen_position.y,instant_position.y);
        int rect_w = abs(chosen_position.x - instant_position.x);
        int rect_h = abs(chosen_position.y - instant_position.y);
        rectStart = Rect(rect_x,rect_y,rect_w,rect_h);
    }
    CDialogEx::OnLButtonUp(nFlags, point);
}

PariticalFilter在MFC上的运行,源代码公开的更多相关文章

  1. Arduino可穿戴教程之第一个程序——上传运行程序(四)

    Arduino可穿戴教程之第一个程序——上传运行程序(四) 2.4.5  上传程序 现在所有Arduino IDE的设置都完成了,我们就可以将示例程序上传到板子中了.这非常简单,只需要单击如图2.45 ...

  2. MFC上显示摄像头JPEG图片数据的两种方法

    其一是借助opencv,其二是利用流对象. 方法一: CvMat *mat; ,,CV_8UC1); ,,CV_8UC1,JPEGBuf); /*初始化矩阵信息头,这里的JPEGBuf就是JPEG图像 ...

  3. iOS开发之使用Storyboard预览UI在不同屏幕上的运行效果

    在公司做项目一直使用Storyboard,虽然有时会遇到团队合作的Storyboard冲突问题,但是对于Storyboard开发效率之高还是比较划算的.在之前的博客中也提到过,团队合作使用Storyb ...

  4. Windows OS上安装运行Apache Kafka教程

    Windows OS上安装运行Apache Kafka教程 下面是分步指南,教你如何在Windows OS上安装运行Apache Zookeeper和Apache Kafka. 简介 本文讲述了如何在 ...

  5. [转].NET程序在windows操作系统上独立运行的技术要点

    发现一个不错的网站,转载一篇文章方便查看 转自 http://www.linuxdot.net/bbsfile-3354   ===================================== ...

  6. 让MFC程序隐藏运行界面

    在MFC中隐藏运行界面确实花花点功力. 针对对话框程序,一种不是很好地实现方法是在OnPaint函数中添加如下代码: CWnd::ShowWindow(SW_HIDE); 添加后执行会发现屏幕会闪烁一 ...

  7. 利用STM32F唯一96bit序列号实现反拷贝加密的源代码公开(转)

    源:利用STM32F唯一96bit序列号实现反拷贝加密的源代码公开 //---------------------------------------------------------------- ...

  8. PowerShell执行脚本时“系统上禁止运行脚本”问题解决

    PowerShell执行脚本策略错误 错误信息:PowerShell运行脚本错误--"系统上禁止运行脚本" 原因:默认执行策略为Restricted 解决:执行Set-Execut ...

  9. npm run dev 在Linux上持久运行

    关于node.js应用程序如何持久运行,我在node.js服务端程序在Linux上持久运行用过. 这次主要是针对是一个vue.js应用程序. vue.js应用程序通常运行命令是npm run dev. ...

随机推荐

  1. Contaminated Milk

    Contaminated Milk 题目描述 Farmer John, known far and wide for the quality of the milk produced on his f ...

  2. PAT (Advanced Level) 1083. List Grades (25)

    简单排序. #include<cstdio> #include<cstring> #include<cmath> #include<vector> #i ...

  3. UWSGITOP-----监控uwsgi 性能

    启动 uwsgi -x etc/bfdds_cookiemapping_conf.xml --stats /tmp/stats.socket 查看 uwsgitop /tmp/stats.socket ...

  4. 内置Web Server

    在终端输入命令:php -S localhost:8000 -t xxx(某个目录或文件) 这个内置的Web服务器主要用于本地开发使用,不可用于线上产品环境. URI请求会被发送到PHP所在的的工作目 ...

  5. windows下使用waveout函数族播放wav文件

    要使用waveout函数组,族,首先要知道几个数据结构,首先是这个 typedef struct tWAVEFORMATEX { WORD wFormatTag; /* 格式的类型 */ WORD n ...

  6. Web开发中需要了解的东西

    在StackExchange上有人问了这样一个问题:What should every programmer know about web development?(关于Web开发,什么是所有程序员需 ...

  7. ajax--2017年1月15日

    听说点六下就能复制了? ajax: 一般处理程序(数据接口):ashx 跨语言传递数据:xml: 结构不清晰 代码量比较大 查找起来比较费事 非面向对象结构 json: 结构清晰 代码量相对较小 面向 ...

  8. Adaptive Server Enterprise ODBC driver connection strings

    Adaptive Server Enterprise 15.0 Driver={Adaptive Server Enterprise};app=myAppName;server=myServerAdd ...

  9. iOS纯代码手动适配 分类: ios技术 2015-05-04 17:14 239人阅读 评论(0) 收藏

    首先说下让自己的程序支持iPhone6和6+,第一种使用官方提供的launch screen.xib,这个直接看官方文档即可,这里不再多述:第二种方法是和之前iPhone5的类似,比较简单,为iPho ...

  10. 详解Objective-C的meta-class 分类: ios相关 ios技术 2015-03-07 15:41 51人阅读 评论(0) 收藏

    比较简单的一篇英文,重点是讲解meta-class.翻译下,加深理解. 原文标题:What is a meta-class in Objective-C? 原文地址:http://www.cocoaw ...