File indexing completed on 2024-04-14 14:07:55

0001 /*************************************************************************************
0002  *  Copyright (C) 2012 by Percy Camilo T. Aucahuasi <percy.camilo.ta@gmail.com>      *
0003  *                                                                                   *
0004  *  This program is free software; you can redistribute it and/or                    *
0005  *  modify it under the terms of the GNU General Public License                      *
0006  *  as published by the Free Software Foundation; either version 2                   *
0007  *  of the License, or (at your option) any later version.                           *
0008  *                                                                                   *
0009  *  This program is distributed in the hope that it will be useful,                  *
0010  *  but WITHOUT ANY WARRANTY; without even the implied warranty of                   *
0011  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                    *
0012  *  GNU General Public License for more details.                                     *
0013  *                                                                                   *
0014  *  You should have received a copy of the GNU General Public License                *
0015  *  along with this program; if not, write to the Free Software                      *
0016  *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA   *
0017  *************************************************************************************/
0018 
0019 #include "surface.h"
0020 
0021 #include "private/functiongraphfactory.h"
0022 #include "private/abstractsurface.h"
0023 
0024 using namespace Analitza;
0025 
0026 Surface::Surface(AbstractFunctionGraph* g): FunctionGraph(g)
0027 {}
0028 
0029 Surface::~Surface()
0030 {}
0031 
0032 void Surface::update(const QVector3D & oppositecorner1, const QVector3D & oppositecorner2)
0033 {
0034     Q_ASSERT(backend());
0035     
0036     static_cast<AbstractSurface*>(backend())->update(oppositecorner1, oppositecorner2);
0037 }
0038 
0039 QVector<QVector3D> Surface::vertices() const
0040 {
0041     Q_ASSERT(backend());
0042 
0043     return static_cast<AbstractSurface*>(backend())->vertices;
0044 }
0045 
0046 QVector<QVector3D> Surface::normals() const
0047 {
0048     Q_ASSERT(backend());
0049 
0050     return static_cast<AbstractSurface*>(backend())->normals;
0051 }
0052 
0053 QVector<unsigned int> Surface::indexes() const
0054 {
0055     Q_ASSERT(backend());
0056 
0057     return static_cast<AbstractSurface*>(backend())->indexes;
0058 }