本文整理匯總了Python中horizons.util.loaders.tilesetloader.TileSetLoader.get_sets方法的典型用法代碼示例。如果您正苦於以下問題:Python TileSetLoader.get_sets方法的具體用法?Python TileSetLoader.get_sets怎麽用?Python TileSetLoader.get_sets使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類horizons.util.loaders.tilesetloader.TileSetLoader
的用法示例。
在下文中一共展示了TileSetLoader.get_sets方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: _loadObject
# 需要導入模塊: from horizons.util.loaders.tilesetloader import TileSetLoader [as 別名]
# 或者: from horizons.util.loaders.tilesetloader.TileSetLoader import get_sets [as 別名]
def _loadObject(cls, db):
"""Loads the ground object from the db (animations, etc)"""
cls._fife_objects = {}
tile_sets = TileSetLoader.get_sets()
tile_set_data = db("SELECT set_id FROM tile_set WHERE ground_id=?", cls.id)
for tile_set_row in tile_set_data:
tile_set_id = str(tile_set_row[0])
cls_name = '%d-%s' % (cls.id, cls.shape)
cls.log.debug('Loading ground %s', cls_name)
fife_object = None
try:
fife_object = horizons.globals.fife.engine.getModel().createObject(cls_name, 'ground_' + tile_set_id)
except RuntimeError:
cls.log.debug('Already loaded ground %d-%s', cls.id, cls.shape)
fife_object = horizons.globals.fife.engine.getModel().getObject(cls_name, 'ground_' + tile_set_id)
return
fife.ObjectVisual.create(fife_object)
visual = fife_object.get2dGfxVisual()
for rotation, data in tile_sets[tile_set_id][cls.shape].iteritems():
assert len(data) == 1, 'Currently only static tiles are supported'
img = horizons.globals.fife.animationloader.load_image(data.keys()[0], tile_set_id, cls.shape, str(rotation))
visual.addStaticImage(rotation, img.getHandle())
# Save the object
cls._fife_objects[tile_set_id] = fife_object
示例2: load_grounds
# 需要導入模塊: from horizons.util.loaders.tilesetloader import TileSetLoader [as 別名]
# 或者: from horizons.util.loaders.tilesetloader.TileSetLoader import get_sets [as 別名]
def load_grounds(cls, db, load_now=False):
cls.log.debug("Entities: loading grounds")
if hasattr(cls, "grounds"):
cls.log.debug("Entities: grounds already loaded")
return
from horizons.world.ground import GroundClass
tile_sets = TileSetLoader.get_sets()
cls.grounds = _EntitiesLazyDict()
for (ground_id,) in db("SELECT ground_id FROM tile_set"):
tile_set_id = db("SELECT set_id FROM tile_set WHERE ground_id=?", ground_id)[0][0]
for shape in tile_sets[tile_set_id].iterkeys():
cls_name = '%d-%s' % (ground_id, shape)
cls.grounds.create_on_access(cls_name, Callback(GroundClass, db, ground_id, shape))
if load_now:
cls.grounds[cls_name]
cls.grounds['-1-special'] = GroundClass(db, -1, 'special')
示例3: _set_cursor_image
# 需要導入模塊: from horizons.util.loaders.tilesetloader import TileSetLoader [as 別名]
# 或者: from horizons.util.loaders.tilesetloader.TileSetLoader import get_sets [as 別名]
def _set_cursor_image(self):
"""Replace the cursor with an image of the selected tile."""
# FIXME the water tile is too big to use as cursor
if self._tile_details[0] == 0:
return
tile = tuple(self._tile_details)
image = TileLayingTool.tile_images.get(tile)
if not image:
tile_sets = TileSetLoader.get_sets()
ground_id, action_id, rotation = tile
set_id = horizons.globals.db.get_random_tile_set(ground_id)
filename = tile_sets[set_id][action_id][rotation].keys()[0]
image = horizons.globals.fife.imagemanager.load(filename)
TileLayingTool.tile_images[tile] = image
horizons.globals.fife.cursor.set(image)
示例4: _loadGroundTiles
# 需要導入模塊: from horizons.util.loaders.tilesetloader import TileSetLoader [as 別名]
# 或者: from horizons.util.loaders.tilesetloader.TileSetLoader import get_sets [as 別名]
def _loadGroundTiles(self):
print("loading UH ground tiles...")
tile_sets = TileSetLoader.get_sets()
for tile_set_id in tile_sets:
tile_set = tile_sets[tile_set_id]
object = self.model.createObject(str(tile_set_id), util.GROUND_NAMESPACE)
fife.ObjectVisual.create(object)
# load animations
for action_id in tile_sets[tile_set_id].iterkeys():
action = object.createAction(action_id+"_"+str(tile_set_id))
fife.ActionVisual.create(action)
for rotation in tile_sets[tile_set_id][action_id].iterkeys():
anim = self.animationloader.loadResource( \
str(tile_set_id)+"+"+str(action_id)+"+"+ \
str(rotation) + ':shift:center+0,bottom+8')
action.get2dGfxVisual().addAnimation(int(rotation), anim)
action.setDuration(anim.getDuration())
示例5: _loadObject
# 需要導入模塊: from horizons.util.loaders.tilesetloader import TileSetLoader [as 別名]
# 或者: from horizons.util.loaders.tilesetloader.TileSetLoader import get_sets [as 別名]
def _loadObject(cls, db):
"""Loads the ground object from the db (animations, etc)"""
cls._fife_objects = {}
tile_sets = TileSetLoader.get_sets()
model = horizons.globals.fife.engine.getModel()
load_image = horizons.globals.fife.animationloader.load_image
tile_set_data = db("SELECT set_id FROM tile_set WHERE ground_id=?", cls.id)
for tile_set_row in tile_set_data:
tile_set_id = str(tile_set_row[0])
cls_name = '{:d}-{}'.format(cls.id, cls.shape)
cls.log.debug('Loading ground %s', cls_name)
fife_object = None
try:
fife_object = model.createObject(cls_name, 'ground_' + tile_set_id)
except fife.NameClash:
cls.log.debug('Already loaded ground %d-%s', cls.id, cls.shape)
fife_object = model.getObject(cls_name, 'ground_' + tile_set_id)
return
fife.ObjectVisual.create(fife_object)
visual = fife_object.get2dGfxVisual()
for rotation, data in tile_sets[tile_set_id][cls.shape].items():
if not data:
raise KeyError('No data found for tile set `{}` in rotation `{}`. '
'Most likely the shape `{}` is missing.'
.format(tile_set_id, rotation, cls.shape))
if len(data) > 1:
raise ValueError('Currently only static tiles are supported. '
'Found this data for tile set `{}` in rotation `{}`: '
'{}'.format(tile_set_id, rotation, data))
img = load_image(list(data.keys())[0], tile_set_id, cls.shape, str(rotation))
# make the drawing origin correspond with the center of the groundpart of the image
# (instead of the center of the image)
img.setYShift(int(img.getWidth() / 4 - img.getHeight() / 2))
visual.addStaticImage(rotation, img.getHandle())
# Save the object
cls._fife_objects[tile_set_id] = fife_object
示例6: _loadObject
# 需要導入模塊: from horizons.util.loaders.tilesetloader import TileSetLoader [as 別名]
# 或者: from horizons.util.loaders.tilesetloader.TileSetLoader import get_sets [as 別名]
def _loadObject(cls, db):
""" Loads the ground object from the db (animations, etc)
"""
cls.log.debug('Loading ground %s', cls.id)
try:
cls._object = horizons.globals.fife.engine.getModel().createObject(str(cls.id), 'ground')
except RuntimeError:
cls.log.debug('Already loaded ground %s', cls.id)
cls._object = horizons.globals.fife.engine.getModel().getObject(str(cls.id), 'ground')
return
fife.ObjectVisual.create(cls._object)
tile_sets = TileSetLoader.get_sets()
for (tile_set_id,) in db("SELECT set_id FROM tile_set WHERE ground_id=?", cls.id):
for action_id in tile_sets[tile_set_id].iterkeys():
action = cls._object.createAction(action_id+"_"+str(tile_set_id))
fife.ActionVisual.create(action)
for rotation in tile_sets[tile_set_id][action_id].iterkeys():
anim = horizons.globals.fife.animationloader.loadResource(
str(tile_set_id)+"+"+str(action_id)+"+"+
str(rotation) + ':shift:center+0,bottom+8')
action.get2dGfxVisual().addAnimation(int(rotation), anim)
action.setDuration(anim.getDuration())
示例7: open
# 需要導入模塊: from horizons.util.loaders.tilesetloader import TileSetLoader [as 別名]
# 或者: from horizons.util.loaders.tilesetloader.TileSetLoader import get_sets [as 別名]
not_found = not_found + 1
continue
# Instead of only float value we need to hold a 'bit' more infos in all_action_sets dictionary
animval = all_action_sets[tileset_id][action_id][rotation][file]
del all_action_sets[tileset_id][action_id][rotation][file]
all_action_sets[tileset_id][action_id][rotation][file_new] = [animval, \
atlases[entry.source], entry.xpos, entry.ypos, entry.width, entry.height]
# Dump it into JSON file
import json
with open(os.path.join("development", "atlas", "actionsets.json"), mode="wb") as fjson:
json.dump(all_action_sets, fjson, indent=1)
# Same stuff with tilesets
all_tile_sets = TileSetLoader.get_sets()
for tileset_id in all_tile_sets:
for action_id in all_tile_sets[tileset_id]:
for rotation in sorted(all_tile_sets[tileset_id][action_id]):
for file in sorted(all_tile_sets[tileset_id][action_id][rotation]):
file_new = file.replace('\\', '/')
try:
entry = mapping[file_new]
except KeyError:
print "Warning: {0} not found".format(file)
not_found = not_found + 1
continue
animval = all_tile_sets[tileset_id][action_id][rotation][file]