summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>1992-09-29 17:07:10 (GMT)
committerGuido van Rossum <guido@python.org>1992-09-29 17:07:10 (GMT)
commit4df20fa80f0e24b065c7ca5ab861f047eda15763 (patch)
tree828f9610da877829ce435041b8d80ee0dc154054
parent384f24816b7a50c7c2c23740bbc1080fcb7a2d3f (diff)
downloadcpython-4df20fa80f0e24b065c7ca5ab861f047eda15763.zip
cpython-4df20fa80f0e24b065c7ca5ab861f047eda15763.tar.gz
cpython-4df20fa80f0e24b065c7ca5ab861f047eda15763.tar.bz2
New tool Vfix: truncate the right edge of 'grey' type images to make
the scanline width a multiple of 4. VFile: use gl.gversion() to distinguish 4.0.1 and 4.0.5 Indigos; truncate width and height to multiples of packfactor. Vinfo: add -t to descriptive comment; print '!' after packfactor for files that should be fixed with Vfix.
-rwxr-xr-xDemo/sgi/video/VFile.py25
-rwxr-xr-xDemo/sgi/video/Vfix.py90
-rwxr-xr-xDemo/sgi/video/Vinfo.py10
3 files changed, 114 insertions, 11 deletions
diff --git a/Demo/sgi/video/VFile.py b/Demo/sgi/video/VFile.py
index 12e087c..6443fb6 100755
--- a/Demo/sgi/video/VFile.py
+++ b/Demo/sgi/video/VFile.py
@@ -309,10 +309,11 @@ class Displayer(VideoParams):
data, width, height, bytes = jpeg.decompress(data)
if self.format == 'jpeg':
b = 4
+ p = 1
else:
b = 1
- width, height = width*pf, height*pf
- if (width, height, bytes) <> (w, h, b):
+ p = pf
+ if (width, height, bytes) <> (w/p, h/p, b):
raise Error, 'jpeg data has wrong size'
if not self.colormapinited:
self.initcolormap()
@@ -359,14 +360,15 @@ class Displayer(VideoParams):
gl.RGBcolor(200, 200, 200) # XXX rather light grey
gl.clear()
return
-## XXX Unfortunately this doesn't work on IRIX 4.0.1...
-## if self.format == 'rgb8' and is_entry_indigo():
-## gl.RGBmode()
-## gl.gconfig()
-## gl.RGBcolor(200, 200, 200) # XXX rather light grey
-## gl.clear()
-## gl.pixmode(GL.PM_SIZE, 8)
-## return
+ # This only works on an Entry-level Indigo from IRIX 4.0.5
+ if self.format == 'rgb8' and is_entry_indigo() and \
+ gl.gversion() == 'GL4DLG-4.0.': # Note trailing '.'!
+ gl.RGBmode()
+ gl.gconfig()
+ gl.RGBcolor(200, 200, 200) # XXX rather light grey
+ gl.clear()
+ gl.pixmode(GL.PM_SIZE, 8)
+ return
gl.cmode()
gl.gconfig()
self.skipchrom = 0
@@ -571,6 +573,9 @@ def readfileheader(fp, filename):
packfactor = 2
else:
raise Error, filename + ': Bad (w,h,pf) info'
+ if packfactor > 1:
+ width = (width / packfactor) * packfactor
+ height = (height / packfactor) * packfactor
#
# Return (version, values)
#
diff --git a/Demo/sgi/video/Vfix.py b/Demo/sgi/video/Vfix.py
new file mode 100755
index 0000000..82465bc
--- /dev/null
+++ b/Demo/sgi/video/Vfix.py
@@ -0,0 +1,90 @@
+#!/ufs/guido/bin/sgi/python
+
+# Copy a video file, fixing the line width to be a multiple of 4
+
+
+# Usage:
+#
+# Vfix [infile [outfile]]
+
+
+# Options:
+#
+# infile : input file (default film.video)
+# outfile : output file (default out.video)
+
+
+import sys
+import imageop
+sys.path.append('/ufs/guido/src/video')
+import VFile
+
+
+# Main program -- mostly command line parsing
+
+def main():
+ args = sys.argv[1:]
+ if len(args) < 1:
+ args.append('film.video')
+ if len(args) < 2:
+ args.append('out.video')
+ if len(args) > 2:
+ sys.stderr.write('usage: Vfix [infile [outfile]]\n')
+ sys.exit(2)
+ sts = process(args[0], args[1])
+ sys.exit(sts)
+
+
+# Copy one file to another
+
+def process(infilename, outfilename):
+ try:
+ vin = VFile.BasicVinFile().init(infilename)
+ except IOError, msg:
+ sys.stderr.write(infilename + ': I/O error: ' + `msg` + '\n')
+ return 1
+ except VFile.Error, msg:
+ sys.stderr.write(msg + '\n')
+ return 1
+ except EOFError:
+ sys.stderr.write(infilename + ': EOF in video file\n')
+ return 1
+
+ try:
+ vout = VFile.BasicVoutFile().init(outfilename)
+ except IOError, msg:
+ sys.stderr.write(outfilename + ': I/O error: ' + `msg` + '\n')
+ return 1
+
+ info = vin.getinfo()
+ if info[0] <> 'grey':
+ sys.stderr.write('Vfix: input not in grey format\n')
+ return 1
+ vout.setinfo(info)
+ inwidth, height = vin.getsize()
+ pf = vin.packfactor
+ if (inwidth/pf)%4 == 0:
+ sys.stderr.write('Vfix: fix not necessary\n')
+ return 1
+ outwidth = (inwidth/pf/4)*4*pf
+ print 'inwidth =', inwidth, 'outwidth =', outwidth
+ vout.setsize(outwidth, height)
+ vout.writeheader()
+ n = 0
+ try:
+ while 1:
+ t, data, cdata = vin.getnextframe()
+ n = n + 1
+ sys.stderr.write('Frame ' + `n` + '...')
+ data = imageop.crop(data, 1, inwidth/pf, height/pf, \
+ 0, 0, outwidth/pf-1, height/pf-1)
+ vout.writeframe(t, data, None)
+ sys.stderr.write('\n')
+ except EOFError:
+ pass
+ return 0
+
+
+# Don't forget to call the main program
+
+main()
diff --git a/Demo/sgi/video/Vinfo.py b/Demo/sgi/video/Vinfo.py
index 22eab23..77ae3a3 100755
--- a/Demo/sgi/video/Vinfo.py
+++ b/Demo/sgi/video/Vinfo.py
@@ -5,7 +5,7 @@
# Usage:
#
-# Vinfo [-d] [-q] [-s] [file] ...
+# Vinfo [-d] [-q] [-s] [-t] [file] ...
# Options:
@@ -13,6 +13,7 @@
# -d : print deltas between frames instead of frame times
# -q : quick: don't read the frames
# -s : don't print times (but do count frames and print the total)
+# -t : terse (one line/file, implies -s)
# file ... : file(s) to inspect; default film.video
@@ -86,6 +87,13 @@ def process(filename):
print string.ljust(vin.format, 8),
print string.rjust(`vin.width`, 4),
print string.rjust(`vin.height`, 4),
+ s = string.rjust(`vin.packfactor`, 2)
+ if vin.packfactor and vin.format not in ('rgb', 'jpeg') and \
+ (vin.width/vin.packfactor) % 4 <> 0:
+ s = s + '!'
+ else:
+ s = s + ' '
+ print s,
sys.stdout.flush()
else:
vin.printinfo()