Welcome, guest | Sign In | My Account | Store | Cart

This DEMO displays the action of an EM87 Magic Eye tuning indicator using a standard Python 2.6.x or greater install. It is for at least Windows Vista 32 Bit and at least Debian Linux 6.0.0.

It is for FUN only and shows how to generate yet another analogue display using a default text mode install.

With careful thought and viewing between Code Page 850, (Windows Vista onwards), and Code Page 437, (EFFECTIVELY Linux), one can pick the "graphics" characters to generate some interesting old style text mode displays on screen.

Enjoy finding simple solutions to often very difficult problems...

Bazza...

Python, 172 lines
  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
# MagicEye.py
#
# A simple animation DEMO to simulate the action of a thermionic tuning indicator valve/tube.
# The valve/tube type is EM87, 6HU6, CV10407, 6E2 and other equivalent numbers too.
# http://www.akh.se/tubes/htm/em87.htm
#
# Original copyright, (C)2011, B.Walker, G0LCU.
# 
# Save the file as MagicEye.py in the Lib and/or Modules drawer/directory/folder.
# To test from a normal Python Command Prompt/Terminal call as......
#
# >>> import MagicEye
#
# ......and away you go and enjoy... ;o)
#
# Tested on Windows Vista using Python 2.6.2 and Debian Linux using Python 2.6.6.
# Also tested on PCLinusOS 2009 using Python 2.5.2... (All are default installs.)
# This code assumes white foreground and black background colours.
#
# Written in such a way that anyone can understand how it works!
# This code CAN be simplified quite a lot but it has been left as is...
#
# It is useful for quick glance readings from say an 8 bit ADC used as a simple level
# indicator, for example a tuning and/or level indicator.
# It is at 5 bit depth.
#
# The commands, "CLS" and "clear" are used and assumed to always be available for both platforms...

# Do any imports for this DEMO as required.
import os
import sys
import random
import time

# Just for this DEMO set all variables as global.
global tlc
global hl
global trc
global vl
global blc
global brc
global fullbox
global shadebox
global topline
global magiceye
global bottomline
global startgap
global count
global grab
global darkcount

# Set the startup variable values.
# tlc == Top lefthand corner character.
# hl == Horizontal line character.
# trc == Top righthand corner character.
# vl == Vertical line character.
# blc == Bottom lefthand corner character.
# brc == Bottom righthand corner character.
# fullbox == Full box character.
# shadebox == Dithered box character.
# count == A re-usable value for this DEMO.
# grab == The psuedo-value to display.
# darkcount == Specific for the shaded "graphics" area only.
tlc=unichr(0x250c)
hl=unichr(0x2500)
trc=unichr(0x2510)
vl=unichr(0x2502)
blc=unichr(0x2514)
brc=unichr(0x2518)
fullbox=unichr(0x2588)
shadebox=unichr(0x2592)
topline=tlc
magiceye="(C)2011, B.Walker, G0LCU."
bottomline=blc
startgap="        "
count=0
grab=255
darkcount=0

# Run continuously until the Ctrl-C keys are pressed.
def main():
	while 1:
		# Set the platform clear screen command for Linux and Windows.
		if sys.platform=="win32": print os.system("CLS"),chr(13),"  ",chr(13),
		if sys.platform=="linux2": print os.system("clear"),chr(13),"  ",chr(13),

		# Randomly generate an 8 bit value as though grabbed from a serial, parallel or USB port.
		grab=int(random.random()*256)
		# Set to a 5 bit value for the DEMO.
		grab=int(grab/8)
		# Although no error should ever occur, never allow one.
		if grab<=0: grab=0
		if grab>=31: grab=31

		# Set up the screen per grab.
		print
		print "A simple pseudo-EM87/6HU6/6E2 tuning indicator style DEMO for standard Python."
		print
		print "Original working idea copyright, (C)2011, B.Walker, G0LCU."
		print
		print "Designed to work on MS Windows, (Vista 32 Bit), using Python 2.6.x."
		print "Also at least Debian Linux using Python 2.6.x too..."
		print
		print
		print "                               EM87/6HU6 simulator."

		# Generate the first line of the MagicEye display.
		topline=startgap+tlc
		count=0
		while count<=61:
			topline=topline+hl
			count=count+1
		topline=topline+trc
		print topline

		# Now generate the MagicEye start only if the grabbed value is GREATER than 0.
		if grab>=1:
			# Do the left hand side very bright part first.
			magiceye=startgap+vl
			count=1
			while count<=grab:
				magiceye=magiceye+fullbox
				count=count+1

			# Now generate the dark centre section.
			count=grab
			darkcount=61-(grab*2)
			while darkcount>=0:
				magiceye=magiceye+shadebox
				darkcount=darkcount-1

			# Finally finish off with another very bright part.
			darkcount=61-(grab*2)
			count=darkcount+grab+1
			while count<=61:
				magiceye=magiceye+fullbox
				count=count+1

		# When the grab value equals 0 override the above and generate a full dark band only.
		if grab==0:
			magiceye=startgap+vl
			count=0
			while count<=61:
				magiceye=magiceye+shadebox
				count=count+1
		# Print the animation to the screen and end with a vertical line.
		print magiceye+vl

		# Now finish off the MagicEye display...
		bottomline=startgap+blc
		count=0
		while count<=61:
			bottomline=bottomline+hl
			count=count+1
		bottomline=bottomline+brc
		print bottomline

		# Finish the screen display.
		print
		print
		print "Grabbed value",grab,"\b..."
		print
		print "Press Ctrl-C to STOP..."
		print

		# Add a short delay for this DEMO...
		time.sleep(0.1)

main()

# End of MagicEye.py DEMO.
# Enjoy finding simple solutions to often very difficult problems. :)

This code is purely for FUN but is functional too. It only requires an 8 bit value to be obtained from say an Arduino or similar device or a parallel or serial port ADC.

1 comment

Barry Walker (author) 11 years, 7 months ago  # | flag

21-08-2012.

Now tested on a MacBook Pro OSX 10,7,3, with Python Version 2.7.1, inside a default Terminal running Python...