1 /************************************************************************* 2 * 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * Copyright 2000, 2010 Oracle and/or its affiliates. 6 * 7 * OpenOffice.org - a multi-platform office productivity suite 8 * 9 * This file is part of OpenOffice.org. 10 * 11 * OpenOffice.org is free software: you can redistribute it and/or modify 12 * it under the terms of the GNU Lesser General Public License version 3 13 * only, as published by the Free Software Foundation. 14 * 15 * OpenOffice.org is distributed in the hope that it will be useful, 16 * but WITHOUT ANY WARRANTY; without even the implied warranty of 17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18 * GNU Lesser General Public License version 3 for more details 19 * (a copy is included in the LICENSE file that accompanied this code). 20 * 21 * You should have received a copy of the GNU Lesser General Public License 22 * version 3 along with OpenOffice.org. If not, see 23 * <http://www.openoffice.org/license.html> 24 * for a copy of the LGPLv3 License. 25 * 26 ************************************************************************/ 27 28 #ifndef _SGVSPLN_HXX 29 #define _SGVSPLN_HXX 30 31 /************************************************************************* 32 |* 33 |* CalcSpline() 34 |* 35 |* Beschreibung Berechnet die Koeffizienten eines parametrischen 36 |* nat�rlichen oder periodischen kubischen 37 |* Polynomsplines. Die Eckpunkte des �bergebenen 38 |* Polygons werden als St�tzstellen angenommen. 39 |* n liefert die Anzahl der Teilpolynome. 40 |* Ist die Berechnung fehlerfrei verlaufen, so 41 |* liefert die Funktion sal_True. Nur in diesem Fall 42 |* ist Speicher f�r die Koeffizientenarrays 43 |* allokiert, der dann sp�ter vom Aufrufer mittels 44 |* delete freizugeben ist. 45 |* Ersterstellung JOE 17-08.93 46 |* Letzte Aenderung JOE 17-08.93 47 |* 48 *************************************************************************/ 49 50 sal_Bool CalcSpline(Polygon& rPoly, sal_Bool Periodic, sal_uInt16& n, 51 double*& ax, double*& ay, double*& bx, double*& by, 52 double*& cx, double*& cy, double*& dx, double*& dy, double*& T); 53 54 /************************************************************************* 55 |* 56 |* Poly2Spline() 57 |* 58 |* Beschreibung Konvertiert einen parametrichen kubischen 59 |* Polynomspline Spline (nat�rlich oder periodisch) 60 |* in ein angen�hertes Polygon. 61 |* Die Funktion liefert sal_False, wenn ein Fehler bei 62 |* der Koeffizientenberechnung aufgetreten ist oder 63 |* das Polygon zu gro?wird (>PolyMax=16380). Im 1. 64 |* Fall hat das Polygon 0, im 2. Fall PolyMax Punkte. 65 |* Um Koordinaten�berl�ufe zu vermeiden werden diese 66 |* auf +/-32000 begrenzt. 67 |* Ersterstellung JOE 23.06.93 68 |* Letzte Aenderung JOE 23.06.93 69 |* 70 *************************************************************************/ 71 sal_Bool Spline2Poly(Polygon& rSpln, sal_Bool Periodic, Polygon& rPoly); 72 73 #endif //_SGVSPLN_HXX 74