//Clasa int utilizată pentru operaţiile cu numere intregi
//prefix Variabile: n
Clasa Întreg
{
operator +, -, *, /, &, |, %, <, >, >=, <=, =, ==, +=, -=, *=, /=, &=, |=, %=, ŞI, SAU, %%, !, min, max; //operatorii şi conversiile din tipul real
Nimic Min (Întreg nA, nB); //întoarce minimul dintre valorile nA şi nB
Nimic Max (Întreg nA, nB); //întoarce maximul dintre valorile nA şi nB
Nimic Abs (Întreg nA); //întoarce valoarea absolută
} //EndInt
//funcţii prietene
Întreg Min (Întreg nA, nB); //întoarce minimul dintre valorile nA şi nB
Întreg Max (Întreg nA, nB); //întoarce maximul dintre valorile nA şi nB
Întreg Abs (Întreg nA); //întoarce valoarea absolută
//Clasa bool utilizată pentru operaţiile logice
//prefix Variabile: b
Clasa Boolean DerivatăDin Întreg
{
} //EndBool
//Clasa real utilizată pentru operaţiile cu numere reale
//prefix Variabile: r
Clasa Real
{
//operatorii
operator +, -, *, /, +=, -=, *=, /=, <, >, <=, >=, =, ==, !=;
//funcţii membru
Nimic Min (Real rA, rB); //întoarce minimul dintre valorile rA şi rB
Nimic Max (Real rA, rB); //întoarce maximul dintre valorile rA şi rB
Nimic Morf(Real rA, rB, rP = 0.5); //întoarce rA * rP + rB * (1.0 - rP)
Nimic Abs (Real rA); //întoarce valoarea absolută
Nimic RotX(Punct pRot, Real rUnghiDeg); //rotaţia în jurul lui X
Nimic RotY(Punct pRot, Real rUnghiDeg); //rotaţia în jurul lui Y
Nimic RotZ(Punct pRot, Real rUnghiDeg); //rotaţia în jurul lui Z
Nimic Scalare(Punct pScalare, Real rFactorScalare); //scalarea faţă de un punct
Nimic Translaţie(Real rTranslaţie); //scalarea faţă de un punct
//suplimentar se pot introduce orice funcţii matematice Ex sin, cos, etc!!
} //real
//funcţii prietene
Real Min (Real rA, rB); //întoarce minimul dintre valorile rA şi rB
Real Max (Real rA, rB); //întoarce maximul dintre valorile rA şi rB
Real Morf(Real rA, rB, rP = 0.5); //întoarce rA * rP + rB * (1.0 - rP)
Real Abs (Real rA); //întoarce valoarea absolută
Real RotX(Punct pRot, Real rUnghiDeg); //rotaţia în jurul lui X
Real RotY(Punct pRot, Real rUnghiDeg); //rotaţia în jurul lui Y
Real RotZ(Punct pRot, Real rUnghiDeg); //rotaţia în jurul lui Z
Real Scalare(Punct pScalare, Real rFactorScalare); //scalarea faţă de un punct
Real Translaţie(Real rTranslaţie); //scalarea faţă de un punct
//Clasa punct utilizată pentru operaţiile cu curbe şi plase
//prefix Variabile: p
Clasa Punct
{
//variabile locale
Real rX, rY, rZ; //coordonatele punctului în R3
//operatorii
operator +, -, *, /, =, ==, +=, -=, *=, /=, min ,max, morf;
//toate funcţiile următoare suportă orice combinaţie de puncte şi reali !!
Nimic Min (PunctpA, pB); //întoarce minimul dintre valorile pA şi pB
Nimic Max (PunctpA, pB); //întoarce maximul dintre valorile pA şi pB
Nimic Morf(PunctpA, pB, pP = 0.5); //întoarce pA * pP + pB * (1.0 - pP)
Nimic Abs (PunctpA); //întoarce valoarea absolută
Nimic RotX(Punct pRot, Real rUnghiDeg); //rotaţia în jurul lui X
Nimic RotY(Punct pRot, Real rUnghiDeg); //rotaţia în jurul lui Y
Nimic RotZ(Punct pRot, Real rUnghiDeg); //rotaţia în jurul lui Z
Nimic Scalare(Punct pScalare, Real rFactorScalare); //scalarea faţă de un punct
Nimic Translaţie(Punct pTranslaţie); //scalarea faţă de un punct
//suplimentar se pot introduce orice funcţii matematice Ex sin, cos, etc!!
} //EndPunct
//funcţii prietene
Punct Min (Punct pA, pB); //întoarce minimul dintre valorile pA şi pB
Punct Max (Punct pA, pB); //întoarce maximul dintre valorile pA şi pB
Punct Morf(Punct pA, pB, pP = 0.5); //întoarce pA * pP + pB * (1.0 - pP)
Punct Abs (Punct pA); //întoarce valoarea absolută
Punct RotX(Punct p, pRot, Real rUnghiDeg); //rotaţia în jurul lui X
Punct RotY(Punct p, pRot, Real rUnghiDeg); //rotaţia în jurul lui Y
Punct RotZ(Punct p, pRot, Real rUnghiDeg); //rotaţia în jurul lui Z
Punct Scalare(Punct p, pScalare, Real rFactorScalare); //scalarea faţă de un punct
Punct Translaţie(Punct p, pTranslaţie); //scalarea faţă de un punct
//Clasa BazăVectorial utilizată la operaţiile cu curbe şi plase în spaţiu
//prefix Variabile: bv
Clasa BazăVectorial
{
operator +, -, *, /, =, +=, -=, *=, /=, min ,max, morf;
Punct pMin; //dreptunghiul înconjurător punctul de start
Punct pMax; //dreptunghiul înconjurător punctul de sfârşit
Punct pDif; //pMax – pMin
} //EndBazăVectorial
//Clasa curbă utilizată operaţiile cu curbe
//prefix Variabile: c
Clasa Curbă DerivatăDin BazăVectorial
{
//variabile locale
Întreg nNr; //numărul de puncte (vertex) în R3
//metode
Punct Operator[] (Întreg nNr); //întoarce punctul numărul nNr = [1..nMax]
Punct Operator[] (Real rT); //întoarce punctul nomând curba rT = [0.0..1.0]
Punct Operator[] (Întreg nNr, Real rT); //întoarce punctul nomând elementul nNr
Nimic PuneLa(Întreg nNr, Punct p); //setează punctul numărul nNr = [1..nMax]
Punct Add(Punct p); //adună un punct
Punct Del(Întreg nNr); //şterge punctul numărul nNr = [1..nMax]
Punct Add(Întreg nNr, Curbă c); //adună o curbă la poziţia dată de nNr
Punct Add(Curbă c); //adună o curbă la sfârşit
Nimic SchimbăSensul(); //schimbă sensul de parcurgere al curbei
Nimic FăTrigonometric(); //face sensul de parcurs al curbei în sens trig.
Nimic FăTrigonometric(); //face sensul de parcurs al curbei în sens trig.
Boolean EsteÎnSensTrig(); //întoarce ADEVĂRAT dacă-i în sens trig.
Boolean EsteÎnSensOrar(); //întoarce ADEVĂRAT dacă-i în sens orar
Boolean EsteÎnchisă(); //întoarce ADEVĂRAT dacă curba este închisă
} //Curbă
//Clasa plasă utilizată la operaţiile cu suprafeţe
//prefix Variabile: l
Clasa Plasă DerivatăDin BazăVectorial
Punct Operator[] (Întreg nU, nV); //întoarce pt. nU=[1..nNrU], nV =[1..nNrV]
Punct IaDeLaUV(Real rU, rV); //întoarce nomând plasa rU,rV = [0.0..1.0]
Curbă IaDeLaXY(Real rX, rY); //proiectează şi returneză o listă cu pt.
Punct Operator[] (Întreg nU, nV, Real rU, rV); //normează elem. NU, nV
Nimic PuneLa(Întreg nU, nV, Punct p); //setează punctul de la nU, nV
Nimic SchimbăSensul(Boolean bU, bV); //schimbă sensul de parcurgere al plasei
FamiliaDeCurbe IaDeLaXY(Întreg nPlasa, Real rX, rY); //proiectează şi returneză o listă
FamiliaDeCurbe IaDeLaU(Real rV); //converteşte în curbă pt rV
FamiliaDeCurbe IaDeLaV(Real rU); //converteşte în curbă pt rU
FamiliaDeCurbe IaDeLaX(Real rX); //converteşte în curbă pt rX
FamiliaDeCurbe IaDeLaY(Real rY); //converteşte în curbă pt rY
FamiliaDeCurbe IaDeLaZ(Real rZ); //converteşte în curbă pt rZ
Real Aria() //calculează aria
Real LungimeaU(Real rV); //lungimea la în dir U la v = rV
Real LungimeaV(Real rU); //lungimea la în dir V la u = rU
Real LungimeaMaxU(); //lungimea maximă în dir U
Real LungimeaMaxV(); //lungimea maximă în dir V
} //EndPlasă
//Clasa de bază pentru suprafeţele discrete de tip real şi mască
//prefix Variabile: bd
Clasa BazăDiscret DerivatăDin BazăVectorial
{
Întreg nX; //numărul de puncte din matrice în direcţia X
Întreg nY; //numărul de puncte din matrice în direcţia Y
Real rStep; //pasul reprezentării
Real IndexÎnRealPtX(Întreg nX); //conversia din index în real pe X
Real IndexÎnRealPtY(Întreg nY); //conversia din index în real pe Y
Întreg RealÎnIndexPtX(Real rX); //conversia din real în index pe X
Întreg RealÎnIndexPtY(Real rY); //conversia din real în index pe Y
} //EndBazăDiscret
//prefix m
Clasa MascăDiscretă DerivatăDin BazăDiscretă
{
operator &, |, -, &=, |=, -=, ;
//citire scriere date
Nimic PuneLa(Întreg nX, Întreg nY, Boolean bVal, Întreg nMetoda = PM_NONE); //pune un bool inteligent
Boolean Operator[] (Întreg nX, Întreg nY); //citeşte un bool
Nimic PuneLa(Real rX, Real rY, Boolean bVal, Întreg nMetoda = PM_NONE); //pune un punct
Boolean Operator[] (Real rX, Real rY); //citeşte un bool
Nimic PuneLaAll(Boolean bvaloare); //setează toată suprafaţa
Nimic Revert(); //schimbă toate valorile
} //EndMascăDiscretă
//prefix s
Clasa SuprafaţăDiscretă DerivatăDin BazăDiscretă
{
MascăDiscretă m; //masca asociată
operator +, -, *, /, +=, -=, *=, /=, =, MAX, MIN, ADD, SUB, MULTIPLY, DIVIDE, MORPH, FILSUS, FILJOS, ECDSUS, ECDJOS;
//citire scriere date
Nimic PuneLa(Întreg nX, Întreg nY, Real rVal, Întreg nMetoda = PM_NONE, Real rMorph = 0.5);
Nimic PuneLa(Real rX, Real rY, Real rVal, Întreg nMetoda = PM_NONE, Real rMorph = 0.5);
Real Operator[] (Întreg nX, Întreg nY); //citeşte un punct
Real Operator[] (Real rX, Real rY); //citeşte un punct
Nimic PuneLaAll(Real rValoare); //seteaza toată suprafaţa
}; //EndSuprafaţăDiscretă
Enumerare ModulDePunere //enumerarea modurilor de combinare solidă a SD şi măştilor
{
PM_NONE, //sdRezultat = sdNouă;
PM_MAX, //sdRezultat = max(sdVeche, sdNouă);
PM_MIN, //sdRezultat = min(sdVeche, sdNouă);
PM_ADD, //sdRezultat = sdVeche + sdNouă;
PM_SUB, //sdRezultat = sdVeche - sdNouă;
PM_MULTIPLY, //sdRezultat = sdVeche * sdNouă;
PM_DIVIDE, //sdRezultat = sdVeche / sdNouă;
PM_MORPH, //sdRezultat = morph(sdVeche, sdNouă, rMorfValue);
PM_FILSUS, //sdRezultat = offset(offset(sdVeche, sdHead, bSus), sdHead, bJos);
PM_FILJOS, //sdRezultat = offset(offset(sdVeche, sdHead, bJos), sdHead, bSus);
PM_ECSDUS, //sdRezultat = offset(sdVeche, sdNouă);
PM_ECDJOS, //sdRezultat = offset(sdVeche, sdNouă);
}
Dostları ilə paylaş: |