Threshold.py 2.4 KB
import sys
import cv2
import numpy as np
from matplotlib import pyplot as plt

def ThresholdEverything(img):
	ret,th1 = cv2.threshold(img,127,255,cv2.THRESH_BINARY)
	th2 = cv2.adaptiveThreshold(img,255,cv2.ADAPTIVE_THRESH_MEAN_C,cv2.THRESH_BINARY,11,2)
	th3 = cv2.adaptiveThreshold(img,255,cv2.ADAPTIVE_THRESH_GAUSSIAN_C,cv2.THRESH_BINARY,11,2)
	titles = ['Original Image', 'Global Thresholding (v = 127)',
	'Adaptive Mean Thresholding', 'Adaptive Gaussian Thresholding']
	images = [img, th1, th2, th3]
	for i in xrange(4):
		plt.subplot(2,2,i+1),plt.imshow(images[i],'gray')
		plt.title(titles[i])
		plt.xticks([]),plt.yticks([])
	plt.show()
	cv2.imwrite('Threshold.png', th1)
	return images

def GlobalThresholding(img):
	ret,th1 = cv2.threshold(img,127,255,cv2.THRESH_BINARY)
	plt.plot(), plt.imshow(th1, 'gray')
	plt.title('Global Thresholding (v = 127)')
	plt.show()
	return th1

def AdaptiveMeanThresholding(img):
	th2 = cv2.adaptiveThreshold(img,255,cv2.ADAPTIVE_THRESH_MEAN_C,cv2.THRESH_BINARY,11,2)
	plt.plot(), plt.imshow(th2, 'gray')
	plt.title('Adaptive Mean Thresholding')
	plt.show()
	return th2

def AdaptiveGaussianThresholding(img):
	th3 = cv2.adaptiveThreshold(img,255,cv2.ADAPTIVE_THRESH_GAUSSIAN_C,cv2.THRESH_BINARY,11,2)
	plt.plot(), plt.imshow(th3, 'gray')
	plt.title('Adaptive Gaussian Thresholding')
	plt.show()
	return th3

def ThresholdChoiceProcessing(img, choice):
	if choice == '1':
		img = GlobalThresholding(img)
		return img
	elif choice == '2':
		img = AdaptiveMeanThresholding(img)
		return img
	elif choice == '3':
		img = AdaptiveGaussianThresholding(img)
		return img
	elif choice == '4':
		img = ThresholdEverything(img)
		return img
	else:
		return


def ThresholdChoice() :
	image = None
	print('\t\tThreshold Menu\n')
	while (image is None):
		if sys.version_info >= (3, 0):
			image = str(input('\tImage to use ? By default couleur.png \n'))
		else:
			image = str(raw_input('\tImage to use ? By default couleur.png \n'))
		if not image:
			image = 'couleur.png'
		image = cv2.imread(str(image), 0)
	img = cv2.medianBlur(image,5)
	print ('\t1. Global Thresholding\n\t2. Adaptive Mean Thresholding\n\t3. Adaptive Gaussian Thresholding\n\t4. Everything\n')
	if sys.version_info >= (3, 0):
		choice = input('\n\tMultiple choices possible\n')
	else:
		choice = raw_input('\n\tMultiple choices possible\n')
	for i in range (0, len(choice)):
		img = image.copy()
		img = ThresholdChoiceProcessing(img, choice[i])
	return