Welcome, guest | Sign In | My Account | Store | Cart
# 4BitVerticalBargraph2x.py
#
# A DEMO 4 bit slow analogue bargraph generator in colour for STANDARD Python 2.6.x and Linux...
# This is a vertical version of the horizontal one also given away by myself.
# It is written so that anyone can understand how it works.
#
# (Original copyright, (C)2011, B.Walker, G0LCU.)
# Issued initially to LXF as Public Domain, and to other sites later.
#
# Saved as 4BitVerticalBargraph2x.py wherever you like.
#
# This DEMO goes from safe green, to warning amber, to danger red, with a crirical
# error beep above 14 on the vertical scale...
# It is a slow "AT A GLANCE" display for quick assessments, not for accuracy.
#
# Two system commands are required, "clear" and "setterm", for this to work.
# I assume that these are available on all recent and current Linux distros.
# The device /dev/audio is used so this must be free also. 
#
# It is useful for quick "AT A GLANCE" readings from say an 8 bit ADC used as a simple
# voltmeter, ammeter, etc. Getting a digital readout is SO simple I left it out this time...
#
# To run use the following from inside a Python prompt...
# >>> exec(open("/full/path/to/code/4BitVerticalBargraph2x.py").read())
# OR...
# >>> execfile("/full/path/to/code/4BitVerticalBargraph2x.py")
#
# This looks like an "LED" style "VU" display...

# Add the required imports for this DEMO.
import os
import random
import time

# Just for this DEMO set up variables as global...
global count
global row
global blank
global greenlines
global yellowlines
global redlines
global waveform

# Startup variable values here.
count=0
row=0
blank="(C)2011, B.Walker, G0LCU."
greenlines=blank
yellowlines=blank
redlines=blank
# This is a square wave binary for the critical error beep.
waveform=chr(15)+chr(45)+chr(63)+chr(45)+chr(15)+chr(3)+chr(0)+chr(3)

def main():
	# Disable the cursor as it looks much nicer... ;o)
	os.system("setterm -cursor off")

	while 1:
		# Run continuously and use Ctrl-C to STOP!
		count=15
		blank="\033[0m                                 "
		# Generate a byte value as though grabbed from a serial, parallel or USB port.
		row=int(random.random()*256)
		# Now divide by 16 to simulate a 4 bit value.
		row=int(row/16)
		# Although this should never occur, don't allow any error.
		if row>=15: row=15
		if row<=0: row=0

		while count>=0:
			# Do a full, clean, clear screen and start looping.
			os.system("clear"),chr(13),"  ",chr(13),
			print "\033[0mFour Bit Level Vertical Analogue Bar Graph Display..."
			print "Original copyright, (C)2011, B.Walker, G0LCU."
			print "Issued to LXF on 24-04-2011 as Public Domain."
			print
			print blank+"\033[1;31m15 __ "
			
			redlines=blank+"\033[1;31m14 __ "
			if row>=15: redlines=redlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print redlines

			redlines=blank+"\033[1;31m13 __ "
			if row>=14: redlines=redlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print redlines

			yellowlines=blank+"\033[1;33m12 __ "
			if row>=13: yellowlines=yellowlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print yellowlines

			yellowlines=blank+"\033[1;33m11 __ "
			if row>=12: yellowlines=yellowlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print yellowlines

			yellowlines=blank+"\033[1;33m10 __ "
			if row>=11: yellowlines=yellowlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print yellowlines

			greenlines=blank+"\033[1;32m 9 __ "
			if row>=10: greenlines=greenlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print greenlines

			greenlines=blank+"\033[1;32m 8 __ "
			if row>=9: greenlines=greenlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print greenlines

			greenlines=blank+"\033[1;32m 7 __ "
			if row>=8: greenlines=greenlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print greenlines

			greenlines=blank+"\033[1;32m 6 __ "
			if row>=7: greenlines=greenlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print greenlines

			greenlines=blank+"\033[1;32m 5 __ "
			if row>=6: greenlines=greenlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print greenlines

			greenlines=blank+"\033[1;32m 4 __ "
			if row>=5: greenlines=greenlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print greenlines

			greenlines=blank+"\033[1;32m 3 __ "
			if row>=4: greenlines=greenlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print greenlines

			greenlines=blank+"\033[1;32m 2 __ "
			if row>=3: greenlines=greenlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print greenlines

			greenlines=blank+"\033[1;32m 1 __ "
			if row>=2: greenlines=greenlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			print greenlines
			
			greenlines=blank+"\033[1;32m 0 __ "
			if row>=1: greenlines=greenlines+unichr(0x2588)+unichr(0x2588)
			count=count-1
			if row==0: greenlines=greenlines+"__"
			count=count-1
			print greenlines
			
			# Reset to default colours...
			print
			print "\033[0mPress Ctrl-C to stop..."

		if row<=14: time.sleep(1)
		if row==15:
			# Set audio timing to zero, "0".
			count=0
			# Open up the audio device to write to.
			# This could be /dev/dsp also...
			audio=open("/dev/audio", "wb")
			# A "count" value of 1 = 1mS, so 1000 = 1S.
			while count<=1000:
				# Send 8 bytes of data to the audio device 1000 times.
				# This is VERY close to 1KHz and almost sinewave.
				audio.write(waveform)
				count=count+1
			# Close the audio device access.
			audio.close()
			
	# Enable the cursor again if it ever gets here... ;oO
	os.system("setterm -cursor on")
main()

# End of DEMO...
# Enjoy finding simple solutions to often very difficult problems...

History