/* Copyright (C) 2001-2003 KSVG Team This file is part of the KDE project This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #include #include "SVGPaint.h" #include "SVGRectImpl.h" #include "SVGEventImpl.h" #include "SVGShapeImpl.h" #include "SVGPaintImpl.h" #include "SVGMatrixImpl.h" #include "SVGDocumentImpl.h" #include "SVGSVGElementImpl.h" #include "SVGAnimatedLengthImpl.h" #include "SVGClipPathElementImpl.h" #include "SVGAnimatedLengthListImpl.h" #include "CanvasItem.h" #include "KSVGCanvas.h" using namespace KSVG; SVGShapeImpl::SVGShapeImpl(DOM::ElementImpl *impl) : SVGElementImpl(impl) { m_item = 0; } SVGShapeImpl::~SVGShapeImpl() { if(hasChildNodes()) { DOM::Node node = firstChild(); for(; !node.isNull(); node = node.nextSibling()) { SVGShapeImpl *rend = dynamic_cast(ownerDoc()->getElementFromHandle(node.handle())); if(rend) rend->deref(); } } } bool SVGShapeImpl::directRender() { SVGShapeImpl *parent = dynamic_cast(ownerDoc()->getElementFromHandle(parentNode().handle())); if(parent) return parent->directRender(); else return true; } SVGRectImpl *SVGShapeImpl::getBBox() { SVGRectImpl *rect = SVGSVGElementImpl::createSVGRect(); return rect; } SVGRectImpl *SVGShapeImpl::getBBoxInternal() { SVGRectImpl *ret = SVGSVGElementImpl::createSVGRect(); if(m_item) { TQRect r = m_item->bbox(); ret->setX(r.x()); ret->setY(r.y()); ret->setWidth(r.width()); ret->setHeight(r.height()); } return ret; } bool SVGShapeImpl::prepareMouseEvent(const TQPoint &p, const TQPoint &, SVGMouseEventImpl *mev) { // TODO : pointer-events should be stored here, not in SVGStylableImpl. SVGStylableImpl *style = dynamic_cast(this); if(!style || style->getPointerEvents() == PE_NONE) return false; bool testFill = false; bool testStroke = false; switch(style->getPointerEvents()) { case PE_VISIBLE: testFill = testStroke = style->getVisible(); break; case PE_VISIBLE_PAINTED: testStroke = style->getVisible() && style->isStroked(); case PE_VISIBLE_FILL: testFill = style->getVisible() && style->isFilled(); break; case PE_VISIBLE_STROKE: testStroke = style->getVisible() && style->isStroked(); break; case PE_PAINTED: testStroke = style->isStroked(); case PE_FILL: testFill = style->isFilled(); break; case PE_STROKE: testStroke = style->isStroked(); break; case PE_ALL: default: testFill = testStroke = true; }; if(testFill || testStroke) { if((testFill && m_item->fillContains(p)) || (testStroke && m_item->strokeContains(p))) { mev->setTarget(this); return true; } } return false; } void SVGShapeImpl::update(CanvasItemUpdate reason, int param1, int param2) { if(m_item) m_item->update(reason, param1, param2); } void SVGShapeImpl::invalidate(KSVGCanvas *c, bool recalc) { if(m_item && c) c->invalidate(m_item, recalc); } void SVGShapeImpl::setReferenced(bool referenced) { if(m_item) m_item->setReferenced(referenced); } void SVGShapeImpl::draw() { if(m_item) m_item->draw(); } void SVGShapeImpl::blit(KSVGCanvas *c) { SVGRectImpl *rect = getBBoxInternal(); c->blit(rect->qrect(), true); rect->deref(); } void SVGShapeImpl::removeItem(KSVGCanvas *c) { if(m_item && c) { c->removeItem(m_item); m_item = 0; } } // vim:ts=4:noet