Friday, February 20, 2015

Opencv turning sketch into 3d model - revit wall

This demo showing using opencv to parse hand sketch, then get imported into a 3d architectural cad software revit from autodesk. You can see how much potential this has. Check video and images below.


in linux load image, and opencv will create a script with location for the walls.

scale can be changed as meter unit

as the script as a file.

open revit a 3d architectural software in windows.

run a macro that adds walls.

load the file created by opencv in linux.

macro will create 3d model for you.

This going to save lots time and free human from tedious drafting works.

Sunday, July 6, 2014

OpenCV Qt4 python Line detection code

there are 2 files. This one is 'opencvLineDetect.py' , which is the main file & gui.
 
import cv2
import numpy as np
import sys
from PySide.QtCore import *
from PySide.QtGui import *
from PySide import QtGui
from PySide import QtCore
from math import *
from CVLineDetection import CVLineDetection

imgPath01 = ['PlanSK_XS.jpg','dummy','dummy']
imgPath02 = 'temp.jpg'
pixelScale = 350
sliderMax = 200
sliderMin = 1
class LineDetection(QtGui.QWidget):
    
    
    def __init__(self):
        super(LineDetection, self).__init__()

 self.pixel = 1
 self.threshold=40
 self.minLineLength=5
 self.maxLineGap=30
        
        self.initUI()
        
        
    def initUI(self):
 #imgPath01 = 'PlanSK_S.jpg'
 #imgPath02 = 'temp.jpg'
 
 
        self._CVLineDetection = CVLineDetection(imgPath01[0])
        self._CVLineDetection.updateImage(imgPath01[0],self.pixel,self.threshold,self.minLineLength,self.maxLineGap)
        
        #labelSliderTxt = QtGui.QLabel('Sliders Left to Right: Pixel, Threshold, MinLineLength, maxLineGap', self)
        fbButton = QtGui.QPushButton("Choose File")
        fbButton.clicked.connect(self.pickFile)
        
        self.slider01TopTxt = QtGui.QLabel('Pixel',self)
        self.slider02TopTxt = QtGui.QLabel('Threshold',self)
        self.slider03TopTxt = QtGui.QLabel('MinLineLength',self)
        self.slider04TopTxt = QtGui.QLabel('MaxLineGap',self)
        
        self.slider01TopLcd = QtGui.QLCDNumber(self)
        self.slider01TopLcd.setSegmentStyle(QtGui.QLCDNumber.Flat)
        self.slider01TopLcd.display(self.pixel)
        self.slider02TopLcd = QtGui.QLCDNumber(self)
        self.slider02TopLcd.setSegmentStyle(QtGui.QLCDNumber.Flat)
        self.slider02TopLcd.display(self.threshold)
        self.slider03TopLcd = QtGui.QLCDNumber(self)
        self.slider03TopLcd.setSegmentStyle(QtGui.QLCDNumber.Flat)
        self.slider03TopLcd.display(self.minLineLength)
        self.slider04TopLcd = QtGui.QLCDNumber(self)
        self.slider04TopLcd.setSegmentStyle(QtGui.QLCDNumber.Flat)
        self.slider04TopLcd.display(self.maxLineGap)
        
        #change pixel
        self.slider = QtGui.QSlider(QtCore.Qt.Vertical)
        self.slider.setFocusPolicy(QtCore.Qt.StrongFocus)
        self.slider.setTickPosition(QtGui.QSlider.TicksBothSides)
        self.slider.setTickInterval(10)
        self.slider.setSingleStep(1)
        self.slider.setValue(self.pixel)
        self.slider.setMaximum(sliderMax)
        self.slider.setMinimum(sliderMin)
        
        self.slider.valueChanged.connect(self.slider01TopLcd.display)
        self.slider.valueChanged.connect(self.refreshImage)
        
        self.slider02 = QtGui.QSlider(QtCore.Qt.Vertical)
        self.slider02.setFocusPolicy(QtCore.Qt.StrongFocus)
        self.slider02.setTickPosition(QtGui.QSlider.TicksBothSides)
        self.slider02.setTickInterval(10)
        self.slider02.setSingleStep(1)
        self.slider02.setValue(self.threshold)
        self.slider02.setMaximum(sliderMax)
        
        self.slider02.valueChanged.connect(self.slider02TopLcd.display)
        self.slider02.valueChanged.connect(self.refreshImage)
        
        self.slider03 = QtGui.QSlider(QtCore.Qt.Vertical)
        self.slider03.setFocusPolicy(QtCore.Qt.StrongFocus)
        self.slider03.setTickPosition(QtGui.QSlider.TicksBothSides)
        self.slider03.setTickInterval(10)
        self.slider03.setSingleStep(1)
        self.slider03.setValue(self.minLineLength)
        self.slider03.setMaximum(sliderMax)
        
        self.slider03.valueChanged.connect(self.slider03TopLcd.display)
        self.slider03.valueChanged.connect(self.refreshImage)
        
        self.slider04 = QtGui.QSlider(QtCore.Qt.Vertical)
        self.slider04.setFocusPolicy(QtCore.Qt.StrongFocus)
        self.slider04.setTickPosition(QtGui.QSlider.TicksBothSides)
        self.slider04.setTickInterval(10)
        self.slider04.setSingleStep(1)
        self.slider04.setValue(self.maxLineGap)
        self.slider04.setMaximum(sliderMax)
        
        
        self.slider04.valueChanged.connect(self.slider04TopLcd.display)
        self.slider04.valueChanged.connect(self.refreshImage)
        
        vboxSlider01 = QtGui.QVBoxLayout()
        vboxSlider01.addStretch(0)
        vboxSlider01.addWidget(self.slider01TopTxt)
        vboxSlider01.addWidget(self.slider01TopLcd)
        vboxSlider01.addWidget(self.slider)
        
        vboxSlider02 = QtGui.QVBoxLayout()
        vboxSlider02.addStretch(0)
        vboxSlider02.addWidget(self.slider02TopTxt)
        vboxSlider02.addWidget(self.slider02TopLcd)
        vboxSlider02.addWidget(self.slider02)
        
        vboxSlider03 = QtGui.QVBoxLayout()
        vboxSlider03.addStretch(0)
        vboxSlider03.addWidget(self.slider03TopTxt)
        vboxSlider03.addWidget(self.slider03TopLcd)
        vboxSlider03.addWidget(self.slider03)
        
        vboxSlider04 = QtGui.QVBoxLayout()
        vboxSlider04.addStretch(0)
        vboxSlider04.addWidget(self.slider04TopTxt)
        vboxSlider04.addWidget(self.slider04TopLcd)
        vboxSlider04.addWidget(self.slider04)
        
        #first image
        pixmap01 = QtGui.QPixmap(imgPath01[0])
        pixmap01 = pixmap01.scaled(pixelScale, pixelScale, QtCore.Qt.KeepAspectRatio) 
        self.imageLable01 = QtGui.QLabel(self)
        self.imageLable01.setPixmap(pixmap01)
        #second image
        pixmap02 = QtGui.QPixmap(imgPath02)
        pixmap02 = pixmap02.scaled(pixelScale, pixelScale, QtCore.Qt.KeepAspectRatio) 
        self.imageLable02 = QtGui.QLabel(self)
        self.imageLable02.setPixmap(pixmap02)
        #add image lable to horizontal box layout
        hbox01 = QtGui.QHBoxLayout()
        hbox01.addStretch(1)
        hbox01.addWidget(self.imageLable01)
        hbox01.addWidget(self.imageLable02)
        hbox01.addLayout(vboxSlider01)
        hbox01.addLayout(vboxSlider02)
        hbox01.addLayout(vboxSlider03)
        hbox01.addLayout(vboxSlider04)
        
        

        hbox = QtGui.QHBoxLayout()
        hbox.addStretch(1)
        #hbox.addWidget(labelSliderTxt)
        hbox.addWidget(fbButton)
        

        vbox = QtGui.QVBoxLayout()
        vbox.addStretch(1)
        vbox.addLayout(hbox01)
        # add sliders
        
        vbox.addLayout(hbox)
        
        self.setLayout(vbox)    
        
        self.setGeometry(300, 300, 300, 150)
        self.setWindowTitle('OpenCV PythonSide Line Detection')    
        self.show()
    def pickFile(self):
        global imgPath01
 imgPath01 = QtGui.QFileDialog.getOpenFileName(self,'Open File',"~/","Images (*.png *.jpg)")
 print imgPath01
 
 self.refreshImage()
 pass
    def refreshImage(self):
        global imgPath01
        self.pixel = self.slider01TopLcd.intValue()
        self.threshold = self.slider02TopLcd.intValue()
        self.minLineLength = self.slider03TopLcd.intValue()
        self.maxLineGap = self.slider04TopLcd.intValue()
        
        self._CVLineDetection.updateImage(imgPath01[0],self.pixel,self.threshold,self.minLineLength,self.maxLineGap)
        pixmap01 = QtGui.QPixmap(imgPath01[0])
        pixmap01 = pixmap01.scaled(pixelScale, pixelScale, QtCore.Qt.KeepAspectRatio) 
        #self.imageLable02 = QtGui.QLabel(self)
        self.imageLable01.setPixmap(pixmap01)
        
        pixmap02 = QtGui.QPixmap(imgPath02)
        pixmap02 = pixmap02.scaled(pixelScale, pixelScale, QtCore.Qt.KeepAspectRatio) 
        #self.imageLable02 = QtGui.QLabel(self)
        self.imageLable02.setPixmap(pixmap02)
        
 pass
    def keyPressEvent(self,event):
 if event.key() == Qt.Key_Escape:
   self.close()
        
        
def main():
    
    app = QtGui.QApplication(sys.argv)
    ex = LineDetection()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()
 
below is the second file ' CVLineDetection.py'
 

import cv2
import numpy as np

class CVLineDetection(object):
  def __init__(self, image01Path01):
    pass
    
  def updateImage(self,image01Path,threshold,minLineLength1,maxLineGap1):
    self.im = cv2.imread(image01Path)
    self.gray = cv2.cvtColor(self.im,cv2.COLOR_BGR2GRAY)
    self.edges = cv2.Canny(self.gray,150,200,apertureSize = 3)
    self.img = self.im.copy()
    
    self.lines = cv2.HoughLinesP(self.edges,1,np.pi/360,threshold, minLineLength=minLineLength1, maxLineGap=maxLineGap1)
    for x1,y1,x2,y2 in self.lines[0]:
      cv2.line(self.img,(x1,y1),(x2,y2),(0,255,0),2)
    cv2.imwrite('temp.jpg',self.img)
    

Thursday, May 1, 2014

OpenCV pySide python QT Line Detection Demo & Code Walkthrough

This is a simple demo and tutorial of using pyside Qt with OpenCV for visual detection. I used Linux as it is easy to setup and run openCV and it is free. With pyside it is easy to create the GUI. As this app is not so complicated, to transform image from cv to qt, I just saved it to disk as jpg for Qt GUI to load it. The interface got several slides, lcd number display and buttons. The original image is on the left, and processed image is on the right. codes are quite straight forward.
What it does is to find straight lines and their coordination on the original image. And then draw them on top of the image.
Below is code walkthrough.