# HG changeset patch # User prock@33b003aa-7bff-0310-803a-e67f0ece8222 # Date 1267041832 0 # Node ID 4f2752d45458eef4f780b4c5467b31a36258ced7 # Parent f44b149f63e7f80878c2b05fb6cf067d5d208972 This changes the behavior of Camera::resetRenderers(). It will no longer activate all layers for every renderer. This is now up to the clients to do. It also adds some code to the map loader that will automatically activate the layers in the InstanceRenderer. Clients that use the any of the renderers will now have to activate the layer they want to use. Also updated rio_de_hola and the editor to reflect changes. fixes[t:457] diff -r f44b149f63e7 -r 4f2752d45458 demos/rio_de_hola/scripts/world.py --- a/demos/rio_de_hola/scripts/world.py Tue Feb 23 19:44:36 2010 +0000 +++ b/demos/rio_de_hola/scripts/world.py Wed Feb 24 20:03:52 2010 +0000 @@ -212,11 +212,17 @@ renderer = fife.FloatingTextRenderer.getInstance(self.cameras['main']) textfont = self.engine.getGuiManager().createFont('fonts/rpgfont.png', 0, str(TDS.readSetting("FontGlyphs", strip=False))); renderer.changeDefaultFont(textfont) - + renderer.activateAllLayers(self.map) + + # Activate the grid renderer on all layers + renderer = self.cameras['main'].getRenderer('GridRenderer') + renderer.activateAllLayers(self.map) + # The small camera shouldn't be cluttered by the 'humm di dums' of our hero. # So we disable the renderer simply by setting its font to None. renderer = fife.FloatingTextRenderer.getInstance(self.cameras['small']) renderer.changeDefaultFont(None) + # The following renderers are used for debugging. # Note that by default ( that is after calling View.resetRenderers or Camera.resetRenderers ) diff -r f44b149f63e7 -r 4f2752d45458 engine/core/view/camera.cpp --- a/engine/core/view/camera.cpp Tue Feb 23 19:44:36 2010 +0000 +++ b/engine/core/view/camera.cpp Wed Feb 24 20:03:52 2010 +0000 @@ -468,7 +468,6 @@ for (; r_it != m_renderers.end(); ++r_it) { Map* map = m_location.getMap(); r_it->second->reset(); - r_it->second->activateAllLayers(map); } } diff -r f44b149f63e7 -r 4f2752d45458 engine/python/fife/extensions/serializers/xmlmap.py --- a/engine/python/fife/extensions/serializers/xmlmap.py Tue Feb 23 19:44:36 2010 +0000 +++ b/engine/python/fife/extensions/serializers/xmlmap.py Wed Feb 24 20:03:52 2010 +0000 @@ -104,7 +104,7 @@ self.parse_layers(mapelt, self.map) self.parse_cameras(mapelt, self.map) - + return self.map def parse_imports(self, mapelt, map): @@ -328,10 +328,14 @@ cam.setRotation(float(rotation)) cam.setTilt(float(tilt)) cam.setZoom(float(zoom)) + + renderer = fife.InstanceRenderer.getInstance(cam) + renderer.activateAllLayers(map) + except fife.Exception, e: print e.getMessage() if self.callback: i += 1 self.callback('loaded camera: ' + str(id), float( i / len(tmplist) * 0.25 + 0.75 ) ) - + diff -r f44b149f63e7 -r 4f2752d45458 tools/editor/scripts/mapcontroller.py --- a/tools/editor/scripts/mapcontroller.py Tue Feb 23 19:44:36 2010 +0000 +++ b/tools/editor/scripts/mapcontroller.py Wed Feb 24 20:03:52 2010 +0000 @@ -88,6 +88,15 @@ break self._layer = self._map.getLayers()[0] + + gridrenderer = self._camera.getRenderer('GridRenderer') + gridrenderer.activateAllLayers(self._map) + + blockrenderer = self._camera.getRenderer('BlockingInfoRenderer') + blockrenderer.activateAllLayers(self._map) + + cellrenderer = self._camera.getRenderer('CellSelectionRenderer') + cellrenderer.activateAllLayers(self._map) def getMap(self): return self._map