// Copyright (C) 2000-2007, Luca Padovani . // // This file is part of GtkMathView, a flexible, high-quality rendering // engine for MathML documents. // // GtkMathView is free software; you can redistribute it and/or modify it // under the terms of the GNU Lesser General Public License as published // by the Free Software Foundation; either version 3 of the License, or // (at your option) any later version. // // GtkMathView 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 // Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public License // along with this program. If not, see . #include #include #include "BoxArea.hh" #include "Rectangle.hh" BoxArea::BoxArea(const AreaRef& area, const BoundingBox& b) : BinContainerArea(area->fit(b.width, b.height, b.depth)), bbox(b) { } AreaRef BoxArea::fit(const scaled&, const scaled&, const scaled&) const { #if 0 AreaRef newChild = getChild()->fit(bbox.width, bbox.height, bbox.depth); if (newChild == getChild()) return this; else return clone(newChild); #endif return this; } void BoxArea::strength(int& w, int& h, int& d) const { w = h = d = 0; } bool BoxArea::searchByCoords(AreaId& id, const scaled& x, const scaled& y) const { if (Rectangle(scaled::zero(), scaled::zero(), box()).isInside(x, y)) { if (BinContainerArea::searchByCoords(id, x, y)) return true; return true; } else return false; }