amin例子的简单研究

amin这个例子,使用了比较复杂高阶的qml技巧,但是也有局限性。下面分3个部分,分别是界面部分,算法部分和扩展部分,简单地对这个问题进行理解。

由衷感谢:http://amin-ahmadi.com/quick-camera-cv/ 给本程序很多借鉴

代码下载地址:https://files.cnblogs.com/files/jsxyhelu/GO_GTD2%E5%AE%8C%E6%88%90.zip

视频地址 :https://files.cnblogs.com/files/jsxyhelu/amin%E4%BE%8B%E5%AD%90%E8%A7%86%E9%A2%91.zip

一、qml界面部分:

1、专门生成了用于提示的dialog

/*
        只有一个OK的弹出界面,目前这个弹出界面只给捕获的时候使用
    */
    Dialog
    {
        property alias text: msgDlgLabel.text
        id: messageDialog
        modal: true
        x: (parent.width - width) / 2
        y: (parent.height - height) / 2

standardButtons: Dialog.Ok
        //上面只有一个label
        Label
        {
            id: msgDlgLabel
            font.bold: true
            wrapMode: Text.Wrap
            width: parent.width
            //点击事件
            onLinkActivated:
            {
                if(link == "图像处理")
                {
                    tabBar.currentIndex = 1
                }
                messageDialog.close()
            }
        }
    }

2、整体界面采用swipe和page以及footer的形式,达到了简洁高效

/*
        主要的swipview界面
    */
    SwipeView
    {
        id: swipeView
        currentIndex: 0
        anchors.rightMargin: 0
        anchors.bottomMargin: 0
        anchors.leftMargin: 0
        anchors.topMargin: 0
        anchors.fill: parent
        //TabBar和swipview要对应起来
        onCurrentIndexChanged:
        {
            tabBar.setCurrentIndex(swipeView.currentIndex)
        }

//视频预览
        Page
        {……

以及

/*
        主要的footer操作
    */
    footer: TabBar {
        id: tabBar
        currentIndex: 0
        padding: 10

3、使用了HTML增加文本显示效果,并且是可以切换的

Text
                            {
                                id: helpText
                                wrapMode: Text.Wrap
                                anchors.left: parent.left
                                anchors.right: parent.right
                                text: "由衷感谢:<a href=\"http://amin-ahmadi.com/quick-camera-cv/\">http://amin-ahmadi.com/quick-camera-cv</a>" +
                                      "给本程序很多借鉴" +
                                      "<br>" +
                                      "<br>" +
                                      "作者博客:" +
                                      "<br>" +
                                      "<a href=\"jsxyhelu.cnblogs.com\">jsxyhelu.cnblogs.com</a>" +
                                      "<br>" +
                                      "<a href=\"jsxyhelu.cnblogs.com\"><img src=\"http://images2015.cnblogs.com/blog/508489/201607/508489-20160731065441684-483128601.png\"  alt=\"欢迎访问!\"></a>"+
                                      "<br>" +
                                      "<b>版权</b>" +
                                      "本程序使用 <a href=\"http://qt.io/\">Qt Framework</a> 作为GUI" +
                                      "<br>" +
                                      "同时使用 <a href=\"http://opencv.org/\">OpenCV</a> 做图像处理算法." +
                                      "<br>" +
                                      "程序采用ICO来自<a href=\"http://flaticon.com/\">Flat Icon</a>."
                                     onLinkActivated:
                                      {
                                           Qt.openUrlExternally(link); 
                                      }

}

应该这样讲,有这段代码作为例子,那么这种样式的程序在界面上基本不成问题。

二、算法实现部分:

qml是弱语法,比较类似lambda,所以这种语言的使用对于习惯c语言的我来说有难度,想要精通需要时间;另一个方面,因为需要和OpenCV进行交互,所以更复杂一点。本例中综合使用了qml使用c++封装出来的对象,以及“信号、槽”机制等;在摄像头获取和图片采集实现中,硬件层综合使用了qml和qcamera,捕获使用了QCameraImageCapture,具体这样用

在qml中,使用

//摄像头选择对话框

ComboBox
                    {
                        id: cameraCombo
                        Layout.fillWidth: true
                        Layout.fillHeight: true
                        model: QtMultimedia.availableCameras
                        textRole: "displayName"

delegate: ItemDelegate
                        {
                            text: modelData.displayName
                        }
                        onCurrentIndexChanged:
                        {
                            camera.stop()
                            camera.deviceId = model[currentIndex].deviceId
                            camera.start()
                        }
                    }

这样可以获得所有可用摄像头的句柄,然后直接传递到c++中

//调用qcamera进行图像采集
void QCvImageProcessor::setCamera(QVariant v)
{
    QObject *o = qvariant_cast<QObject *>(v);
    camera = qvariant_cast<QCamera *>(o->property("mediaObject"));
    camera->setCaptureMode(QCamera::CaptureStillImage);
    imageCapture = new QCameraImageCapture(camera);
    camera->focus()->setFocusMode(QCameraFocus::ContinuousFocus);
    camera->focus()->setFocusPointMode(QCameraFocus::FocusPointAuto);
    //直接在这里设置动作级联
    connect(imageCapture, &QCameraImageCapture::imageSaved, [this](int id, const QString &fileName)
    {
        Q_UNUSED(id);
        processSavedImage(fileName);
    });
}

void QCvImageProcessor::capture()
{
    if(imageCapture->isReadyForCapture())
    {
        //注意这里获得一个可用的图片地址的方法
        imageCapture->capture(QStandardPaths::writableLocation(QStandardPaths::PicturesLocation));
       
    }
    else
    {
        emit errorOccured("Camera is not ready to capture.");
    }
}

还是使用QCameraImageCapture,QCamera来完成捕获。

由于在andoird中,videocapture不能给使用,那么qcamera作为qt专属,来实现摄像头采集功能是非常合适的,这里给出了具体系统方法。

三、进一步扩展部分:

QCameraImageCapture只能捕获静态图片,但是作为一个完整的图像处理程序,一定要能够处理并显示实时的视频数据,如何解决?继续探索!

感谢阅读至此,希望有所帮助。

来自为知笔记(Wiz)

附件列表

原文地址:https://www.cnblogs.com/jsxyhelu/p/8366492.html

时间: 2024-10-20 09:58:51

amin例子的简单研究的相关文章

Android中关于JNI 的学习(零)简单的例子,简单地入门

Android中JNI的作用,就是让Java能够去调用由C/C++实现的代码,为了实现这个功能,需要用到Anrdoid提供的NDK工具包,在这里不讲如何配置了,好麻烦,配置了好久... 本质上,Java去调用C/C++的代码其实就是去调用C/C++提供的方法,所以,第一步,我们要创建一个类,并且定义一个Native方法,如下: JniTest类: public class JniTest { public native String getTestString(); } 可以看到,在这个方法的前

Redis 通信协议简单研究

1.Redis网络通信协议 Redis底层网络通信协议其实是通过TCP来完成的. 2.Redis通信协议 Redis的通信协议首先是以行来划分,每行以\r\n行结束.每一行都有一个消息头,消息头共分为5种分别如下: (+) 表示一个正确的状态信息,具体信息是当前行+后面的字符. (-) 表示一个错误信息,具体信息是当前行-后面的字符. (*) 表示消息体总共有多少行,不包括当前行,*后面是具体的行数. (\() 表示下一行数据长度,不包括换行符长度\r\n,\)后面则是对应的长度的数据. (:)

关于flask线程安全的简单研究

flask是python web开发比较主流的框架之一,也是我在工作中使用的主要开发框架.一直对其是如何保证线程安全的问题比较好奇,所以简单的探究了一番,由于只是简单查看了源码,并未深入细致研究,因此以下内容仅为个人理解,不保证正确性. 首先是很多文章都说flask会为每一个request启动一个线程,每个request都在单独线程中处理,因此保证了线程安全.于是就做了一个简单的测试.首先是写一个简单的flask程序(只需要有最简单的功能用于测试即可),然后我们知道一个flask应用启动之后实际

OpenGL的简单研究-开端

一直想要学习的但是没有学习的东西,大学一直在等待这个时间,终于可以闲下来研究一下这个部分的内容了. 计算机图形学,让计算机处理各种图像的东西,里面也存在很多算法和数学知识,很值得研究的一个领域,之前一直混迹在各种Web和服务器之中,终于可以学一些感觉很酷的东西.其实Web服务器也很酷. 我准备的运行环境还是比较简单的,是Win10操作系统,VS2015的开发环境.因为这种方式配置简单一些,之前试过使用GCC作为编译器和CFree作为开发环境,一直不成功,于是就用开了VC开发. 环境配置的过程是在

IOS Animation-CABasicAnimation例子(简单动画实现)

这些例子都是CABasicAnimation的一些简单实现的动画,例如移动.透明度.翻转等等.方法里面传入一个CALayer类或者子类就可以了. 下面是用swift实现的,这些方法我们也可以用作公共类来调用: //移动动画position func addLayerAnimationPosition(layer: CALayer) { let animation = CABasicAnimation(keyPath: "position") //开始的位置 animation.from

简单研究Android View绘制一

2015-07-27 16:52:58 一.如何通过继承ViewGroup来实现自定义View?首先得搞清楚Android时如何绘制View的,参考Android官方文档:How Android Draws Views 以下翻译摘自:http://blog.csdn.net/linghu_java/article/details/23882681,这也是一片好文章,推荐大家看看- When an Activity receives focus, it will be requested to d

简单研究Android View绘制三 布局过程

2015-07-28 17:29:19 这一篇主要看看布局过程 一.布局过程肯定要不可避免的涉及到layout()和onLayout()方法,这两个方法都是定义在View.java中,源码如下: 1 /** 2 * Assign a size and position to a view and all of its 3 * descendants 4 * 5 * <p>This is the second phase of the layout mechanism. 6 * (The fir

IOS Animation-CAKeyframeAnimation例子(简单动画实现)

在阅读本文之前,可以看看 CABasicAnimation的例子 也可以看看IOS Animation-CABasicAnimation.CAKeyframeAnimation详解&区别&联系 1)让一个layer左右晃动 1 //让一个layer左右晃动 2 func addLayerKeyframeAnimationRock(layer:CALayer) { 3 let animation = CAKeyframeAnimation(keyPath: "position.x&

unity插件开发——一个例子:简单的svn集成

在unity开发过程中,通常我们习惯性地在Windows操作系统下使用svn进行版本管理,而每次提交更新,都需要回到文件夹下的这种操作让人无法忍受.是不是可以集成svn到unity中呢?查了一圈unity store可以看到很多svn的第三方插件.考虑到我们只需要简单的功能,而且不希望加入额外复杂的代码,最后还是自己写一个插件.功能就是更新或者提交assets文件夹. 如果还没有svn对项目进行管理的,按照以下2步操作:     1.下载svn客户端,安装.     2.从svn版本库check