Mercurial > fife-parpg
diff engine/core/view/renderers/genericrenderer.cpp @ 445:f855809822cf
* Fixed GenericRenderer, now it only render to a specific layer. If the node is only a point then it used the last active layer. fixes #[ticket:458]
author | helios2000@33b003aa-7bff-0310-803a-e67f0ece8222 |
---|---|
date | Wed, 24 Mar 2010 16:11:30 +0000 |
parents | ad1f09d954f9 |
children | 16c2b3ee59ce |
line wrap: on
line diff
--- a/engine/core/view/renderers/genericrenderer.cpp Wed Mar 24 13:29:16 2010 +0000 +++ b/engine/core/view/renderers/genericrenderer.cpp Wed Mar 24 16:11:30 2010 +0000 @@ -49,24 +49,52 @@ namespace FIFE { static Logger _log(LM_VIEWVIEW); + GenericRendererNode::GenericRendererNode(Instance* attached_instance, Location* relative_location, Layer* relative_layer, const Point &relative_point): + m_instance(attached_instance), + m_location(relative_location), + m_layer(relative_layer), + m_point(relative_point) { + } GenericRendererNode::GenericRendererNode(Instance* attached_instance, Location* relative_location, const Point &relative_point): m_instance(attached_instance), m_location(relative_location), + m_layer(NULL), + m_point(relative_point) { + } + GenericRendererNode::GenericRendererNode(Instance* attached_instance, Layer* relative_layer, const Point &relative_point): + m_instance(attached_instance), + m_location(NULL), + m_layer(relative_layer), m_point(relative_point) { } GenericRendererNode::GenericRendererNode(Instance* attached_instance, const Point &relative_point): m_instance(attached_instance), m_location(NULL), + m_layer(NULL), + m_point(relative_point) { + } + GenericRendererNode::GenericRendererNode(Location* attached_location, Layer* relative_layer, const Point &relative_point): + m_instance(NULL), + m_location(attached_location), + m_layer(relative_layer), m_point(relative_point) { } GenericRendererNode::GenericRendererNode(Location* attached_location, const Point &relative_point): m_instance(NULL), m_location(attached_location), + m_layer(NULL), + m_point(relative_point) { + } + GenericRendererNode::GenericRendererNode(Layer* attached_layer, const Point &relative_point): + m_instance(NULL), + m_location(NULL), + m_layer(attached_layer), m_point(relative_point) { } GenericRendererNode::GenericRendererNode(const Point &attached_point): m_instance(NULL), m_location(NULL), + m_layer(NULL), m_point(attached_point) { } GenericRendererNode::~GenericRendererNode() { @@ -97,6 +125,9 @@ m_instance = NULL; m_location = attached_location; } + void GenericRendererNode::setAttached(Layer* attached_layer) { + m_layer = attached_layer; + } void GenericRendererNode::setAttached(const Point &attached_point) { m_instance = NULL; m_location = NULL; @@ -135,6 +166,12 @@ } return m_location; } + Layer* GenericRendererNode::getAttachedLayer() { + if(m_layer == NULL) { + throw NotSupported("No layer attached."); + } + return m_layer; + } Point GenericRendererNode::getAttachedPoint() { if(m_instance != NULL || m_location != NULL) { throw NotSupported("No point attached."); @@ -161,6 +198,9 @@ Location* GenericRendererNode::getLocation() { return m_location; } + Layer* GenericRendererNode::getLayer() { + return m_layer; + } Point GenericRendererNode::getPoint() { return m_point; } @@ -168,18 +208,26 @@ Point GenericRendererNode::getCalculatedPoint(Camera* cam, Layer* layer, std::vector<Instance*>& instances) { ScreenPoint p; if(m_instance != NULL) { + if(m_layer == NULL) { + m_layer = m_instance->getLocation().getLayer(); + } if(m_location != NULL) { p = cam->toScreenCoordinates(m_instance->getLocationRef().getMapCoordinates() + m_location->getMapCoordinates()); - } - else { + } else { p = cam->toScreenCoordinates(m_instance->getLocation().getMapCoordinates()); } - } - else if(m_location != NULL) { + } else if(m_location != NULL) { + if(m_layer == NULL) { + m_layer = m_location->getLayer(); + } p = cam->toScreenCoordinates(m_location->getMapCoordinates()); + } else if(m_layer == NULL) { + const std::list<Layer*>& layers = cam->getRenderer("GenericRenderer")->getActiveLayers(); + std::list<Layer*>::const_iterator layer_it = layers.begin(); + for (; layer_it != layers.end(); ++layer_it) { + setAttached(*layer_it); + } } - else - return m_point; return Point(m_point.x + p.x, m_point.y + p.y); } @@ -194,7 +242,9 @@ void GenericRendererLineInfo::render(Camera* cam, Layer* layer, std::vector<Instance*>& instances, RenderBackend* renderbackend, ImagePool* imagepool, AnimationPool* animpool) { Point p1 = m_edge1.getCalculatedPoint(cam, layer, instances); Point p2 = m_edge2.getCalculatedPoint(cam, layer, instances); - renderbackend->drawLine(p1, p2, m_red, m_green, m_blue); + if(m_edge1.getLayer() == layer) { + renderbackend->drawLine(p1, p2, m_red, m_green, m_blue); + } } GenericRendererPointInfo::GenericRendererPointInfo(GenericRendererNode anchor, uint8_t r, uint8_t g, uint8_t b): @@ -206,7 +256,9 @@ } void GenericRendererPointInfo::render(Camera* cam, Layer* layer, std::vector<Instance*>& instances, RenderBackend* renderbackend, ImagePool* imagepool, AnimationPool* animpool) { Point p = m_anchor.getCalculatedPoint(cam, layer, instances); - renderbackend->putPixel(p.x, p.y, m_red, m_green, m_blue); + if(m_anchor.getLayer() == layer) { + renderbackend->putPixel(p.x, p.y, m_red, m_green, m_blue); + } } GenericRendererQuadInfo::GenericRendererQuadInfo(GenericRendererNode n1, GenericRendererNode n2, GenericRendererNode n3, GenericRendererNode n4, uint8_t r, uint8_t g, uint8_t b): @@ -224,7 +276,9 @@ Point p2 = m_edge2.getCalculatedPoint(cam, layer, instances); Point p3 = m_edge3.getCalculatedPoint(cam, layer, instances); Point p4 = m_edge4.getCalculatedPoint(cam, layer, instances); - renderbackend->drawQuad(p1, p2, p3, p4, m_red, m_green, m_blue); + if(m_edge1.getLayer() == layer) { + renderbackend->drawQuad(p1, p2, p3, p4, m_red, m_green, m_blue); + } } GenericRendererVertexInfo::GenericRendererVertexInfo(GenericRendererNode center, int size, uint8_t r, uint8_t g, uint8_t b): @@ -237,7 +291,9 @@ } void GenericRendererVertexInfo::render(Camera* cam, Layer* layer, std::vector<Instance*>& instances, RenderBackend* renderbackend, ImagePool* imagepool, AnimationPool* animpool) { Point p = m_center.getCalculatedPoint(cam, layer, instances); - renderbackend->drawVertex(p, m_size, m_red, m_green, m_blue); + if(m_center.getLayer() == layer) { + renderbackend->drawVertex(p, m_size, m_red, m_green, m_blue); + } } GenericRendererImageInfo::GenericRendererImageInfo(GenericRendererNode anchor, int image): @@ -247,13 +303,15 @@ } void GenericRendererImageInfo::render(Camera* cam, Layer* layer, std::vector<Instance*>& instances, RenderBackend* renderbackend, ImagePool* imagepool, AnimationPool* animpool) { Point p = m_anchor.getCalculatedPoint(cam, layer, instances); - Image* img = &imagepool->getImage(m_image); - Rect r; - r.x = p.x-img->getWidth()/2; - r.y = p.y-img->getHeight()/2; - r.w = img->getWidth(); - r.h = img->getHeight(); - img->render(r); + if(m_anchor.getLayer() == layer) { + Image* img = &imagepool->getImage(m_image); + Rect r; + r.x = p.x-img->getWidth()/2; + r.y = p.y-img->getHeight()/2; + r.w = img->getWidth(); + r.h = img->getHeight(); + img->render(r); + } } GenericRendererAnimationInfo::GenericRendererAnimationInfo(GenericRendererNode anchor, int animation): @@ -265,15 +323,17 @@ } void GenericRendererAnimationInfo::render(Camera* cam, Layer* layer, std::vector<Instance*>& instances, RenderBackend* renderbackend, ImagePool* imagepool, AnimationPool* animpool) { Point p = m_anchor.getCalculatedPoint(cam, layer, instances); - Animation& animation = animpool->getAnimation(m_animation); - int animtime = scaleTime(m_time_scale, TimeManager::instance()->getTime() - m_start_time) % animation.getDuration(); - Image* img = animation.getFrameByTimestamp(animtime); - Rect r; - r.x = p.x-img->getWidth()/2; - r.y = p.y-img->getHeight()/2; - r.w = img->getWidth(); - r.h = img->getHeight(); - img->render(r); + if(m_anchor.getLayer() == layer) { + Animation& animation = animpool->getAnimation(m_animation); + int animtime = scaleTime(m_time_scale, TimeManager::instance()->getTime() - m_start_time) % animation.getDuration(); + Image* img = animation.getFrameByTimestamp(animtime); + Rect r; + r.x = p.x-img->getWidth()/2; + r.y = p.y-img->getHeight()/2; + r.w = img->getWidth(); + r.h = img->getHeight(); + img->render(r); + } } GenericRendererTextInfo::GenericRendererTextInfo(GenericRendererNode anchor, AbstractFont* font, std::string text): @@ -284,13 +344,15 @@ } void GenericRendererTextInfo::render(Camera* cam, Layer* layer, std::vector<Instance*>& instances, RenderBackend* renderbackend, ImagePool* imagepool, AnimationPool* animpool) { Point p = m_anchor.getCalculatedPoint(cam, layer, instances); - Image* img = m_font->getAsImageMultiline(m_text); - Rect r; - r.x = p.x-img->getWidth()/2; - r.y = p.y-img->getHeight()/2; - r.w = img->getWidth(); - r.h = img->getHeight(); - img->render(r); + if(m_anchor.getLayer() == layer) { + Image* img = m_font->getAsImageMultiline(m_text); + Rect r; + r.x = p.x-img->getWidth()/2; + r.y = p.y-img->getHeight()/2; + r.w = img->getWidth(); + r.h = img->getHeight(); + img->render(r); + } } GenericRenderer* GenericRenderer::getInstance(IRendererContainer* cnt) {