<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
案例:使用OpenCV的GrapCut實現有使用者互動的摳圖
grabCut( InputArray img, InputOutputArray mask, Rect rect, InputOutputArray bgdModel, InputOutputArray fgdModel, int iterCount, int mode = GC_EVAL );
實現演演算法的步驟:
1.建立一個遮罩,並初始化為背景GC_BGD
2.使用者選定一個ROI區域初始化為前景GC_FGD
3.呼叫grabCut函數實現演演算法
4.輸入mask即為目標摳圖
(這個例子不完善,影象的顏色輸出有問題,先記錄一下,後面改正。但是不影響整個演演算法的流程及效果,僅僅是RGB和BGR畫素通道的問題)
CrabCut_Matting::CrabCut_Matting(QWidget *parent) : MyGraphicsView{parent} { this->setWindowTitle("crabCut摳圖"); this->setMouseTracking(true);//設定滑鼠事件可用 init = false; numRun = false; } void CrabCut_Matting::dropEvent(QDropEvent*event){ QString filePath = event->mimeData()->urls().at(0).toLocalFile(); showCrabCutMatting(filePath.toStdString().c_str()); } void CrabCut_Matting::showCrabCutMatting(const char* filePath){ src = imread(filePath); if(src.empty()){ qDebug()<<"輸入影象為空"; return; } //建立一個背景遮罩 mMask = Mat::zeros(src.size(),CV_8UC1); mMask.setTo(Scalar::all(GC_BGD)); convert2Sence(src); } void CrabCut_Matting::mouseMoveEvent(QMouseEvent *event){ // if(event->button()==Qt::LeftButton){//滑鼠左鍵 rect = Rect(Point(rect.x, rect.y), Point(event->pos().x(), event->pos().y())); qDebug()<<"mouseMoveEvent:"<<rect.width<<"|"<<rect.height; showImage(); // } } void CrabCut_Matting::mousePressEvent(QMouseEvent *event){ grabMouse(); if(event->button()==Qt::LeftButton){//滑鼠左鍵 rect.x = event->pos().x(); rect.y = event->pos().y(); rect.width = 1; rect.height = 1; init = false; numRun = 0; qDebug()<<"mousePressEvent:"<<event->pos().x()<<"|"<<event->pos().y(); } } void CrabCut_Matting::mouseReleaseEvent(QMouseEvent *event){ releaseMouse(); if(event->button()==Qt::LeftButton){//滑鼠左鍵 if (rect.width > 1 && rect.height > 1) { setROIMask(); qDebug()<<"mouseReleaseEvent:"<<rect.width<<"|"<<rect.height; //執行grabcut的程式碼 runGrabCut(); numRun++; showImage(); } } } /** * 將選中的區域設定為前景 * @brief CrabCut_Matting::setROIMask */ void CrabCut_Matting::setROIMask(){ // GC_FGD = 1 // GC_BGD =0; // GC_PR_FGD = 3 // GC_PR_BGD = 2 mMask.setTo(GC_BGD); rect.x = max(0, rect.x); rect.y = max(0, rect.y); rect.width = min(rect.width, src.cols - rect.x); rect.height = min(rect.height, src.rows - rect.y); mMask(rect).setTo(Scalar(GC_PR_FGD));//將選中的區域設定為 } void CrabCut_Matting::showImage(){ Mat result, binMask; binMask.create(mMask.size(), CV_8UC1); binMask = mMask & 1; if (init) { src.copyTo(result, binMask); } else { src.copyTo(result); } rectangle(result, rect, Scalar(0, 0, 255), 2, 8); convert2Sence(result); } void CrabCut_Matting::runGrabCut(){ if (rect.width < 2 || rect.height < 2) { return; } if (init) { grabCut(src, mMask, rect, bgModel, fgModel, 1); } { grabCut(src, mMask, rect, bgModel, fgModel, 1, GC_INIT_WITH_RECT); init = true; } } void CrabCut_Matting::convert2Sence(Mat target){ scene.clear(); QImage image = ImageUtils::matToQImage(target); QPixmap pixmap = QPixmap::fromImage(image); QGraphicsPixmapItem *item = new QGraphicsPixmapItem(pixmap.scaled(this->size(),Qt::KeepAspectRatio,Qt::SmoothTransformation)); scene.addItem(item); }
以上就是OpenCV使用GrabCut實現摳圖功能的詳細內容,更多關於OpenCV GrabCut摳圖的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45