2013-10-29 23:57:49 -04:00
|
|
|
import sys
|
|
|
|
import os
|
|
|
|
|
|
|
|
from pyglet.gl import GLint, glGetIntegerv, GL_MAX_TEXTURE_SIZE
|
|
|
|
from ctypes import byref
|
|
|
|
|
|
|
|
buf = GLint()
|
|
|
|
glGetIntegerv(GL_MAX_TEXTURE_SIZE, byref(buf))
|
|
|
|
max_texture = buf.value
|
|
|
|
|
|
|
|
del byref, GLint, glGetIntegerv, GL_MAX_TEXTURE_SIZE, buf
|
|
|
|
|
|
|
|
def resize(width, height, target):
|
|
|
|
factor = (target + .0) / max(width, height)
|
|
|
|
return int(width * factor), int(height * factor)
|
|
|
|
|
|
|
|
def fits(width, height):
|
|
|
|
return width < max_texture and height < max_texture
|
|
|
|
|
|
|
|
def make_name(image, suffix):
|
|
|
|
name, ext = os.path.splitext(image)
|
|
|
|
return '%s_%s%s' % (name, suffix, ext)
|
|
|
|
|
|
|
|
try:
|
|
|
|
import pgmagick
|
|
|
|
|
|
|
|
def get_image(image):
|
|
|
|
return pgmagick.Image(image)
|
|
|
|
|
|
|
|
def get_size(image):
|
|
|
|
size = image.size()
|
|
|
|
return size.width(), size.height()
|
|
|
|
|
|
|
|
def scale(image, width, height):
|
|
|
|
image.filterType(pgmagick.FilterTypes.LanczosFilter)
|
|
|
|
image.scale(pgmagick.Geometry(width, height))
|
|
|
|
return image
|
|
|
|
|
|
|
|
def save(image, file):
|
|
|
|
image.write(file)
|
|
|
|
except ImportError:
|
|
|
|
import Image
|
|
|
|
|
|
|
|
def get_image(image):
|
|
|
|
return Image.open(image)
|
|
|
|
|
|
|
|
def get_size(image):
|
|
|
|
return image.size
|
|
|
|
|
|
|
|
def scale(image, width, height):
|
2013-10-30 19:09:04 -04:00
|
|
|
original_width, original_height = image.size
|
|
|
|
if width * 3 < original_width and height * 3 < original_height:
|
|
|
|
image = image.resize((width * 2, height * 2))
|
2013-10-29 23:57:49 -04:00
|
|
|
return image.resize((width, height), Image.ANTIALIAS)
|
|
|
|
|
|
|
|
def save(image, file):
|
|
|
|
image.save(file)
|
|
|
|
|
|
|
|
def shrink(file):
|
|
|
|
image = get_image(file)
|
|
|
|
width, height = get_size(image)
|
|
|
|
if fits(width, height):
|
|
|
|
print 'no need'
|
|
|
|
return
|
|
|
|
width, height = resize(width, height, 2048)
|
|
|
|
if fits(width, height):
|
|
|
|
size = 'medium'
|
|
|
|
else:
|
|
|
|
width, height = resize(width, height, 1024) # 1024 is minimum
|
|
|
|
size = 'small'
|
|
|
|
print 'size %s, %dx%d...' % (size, width, height),
|
|
|
|
name = make_name(file, size)
|
|
|
|
if not os.path.exists(name):
|
|
|
|
image = scale(image, width, height)
|
|
|
|
print 'saved to:', os.path.basename(name)
|
|
|
|
save(image, name)
|
|
|
|
else:
|
|
|
|
print
|
|
|
|
|
|
|
|
textures = [
|
|
|
|
'earth.jpg',
|
|
|
|
'moon.jpg',
|
|
|
|
'mars.jpg',
|
|
|
|
'jupiter.jpg',
|
|
|
|
'saturn.jpg',
|
|
|
|
'moons/io.jpg',
|
|
|
|
'moons/europa.jpg',
|
|
|
|
'moons/ganymede.jpg',
|
|
|
|
'moons/callisto.jpg',
|
|
|
|
'moons/titan.jpg',
|
|
|
|
'moons/rhea.jpg',
|
|
|
|
'moons/iapetus.jpg',
|
|
|
|
'moons/dione.jpg',
|
|
|
|
'moons/tethys.jpg',
|
|
|
|
'moons/enceladus.jpg',
|
|
|
|
'moons/mimas.jpg',
|
|
|
|
]
|
|
|
|
|
|
|
|
def frozen():
|
|
|
|
import imp
|
|
|
|
return (hasattr(sys, "frozen") or # new py2exe
|
|
|
|
hasattr(sys, "importers") # old py2exe
|
|
|
|
or imp.is_frozen("__main__")) # tools/freeze
|
|
|
|
|
|
|
|
def get_main_dir():
|
|
|
|
if frozen():
|
|
|
|
return os.path.dirname(sys.executable)
|
|
|
|
return os.path.dirname(__file__)
|
|
|
|
|
|
|
|
def main():
|
|
|
|
texture = os.path.join(get_main_dir(), 'punyverse', 'assets', 'textures')
|
|
|
|
for file in textures:
|
|
|
|
print 'Resizing %s:' % file,
|
|
|
|
file = os.path.join(texture, file.replace('/', os.sep))
|
|
|
|
shrink(file)
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|