Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Le novità ASUS per il 2026 nel settore dei PC desktop
Le novità ASUS per il 2026 nel settore dei PC desktop
Molte le novità anticipate da ASUS per il 2026 al CES di Las Vegas: da schede madri per processori AMD Ryzen top di gamma a chassis e ventole, passando per i kit di raffreddamento all in one integrati sino a una nuova scheda video GeForce RTX 5090. In sottofondo il tema dell'intelligenza artificiale con una workstation molto potente per installazioni non in datacenter
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-09-2009, 11:24   #1
bettaskate89
Junior Member
 
L'Avatar di bettaskate89
 
Iscritto dal: Sep 2009
Messaggi: 2
[C++ ROOT]Problema con TGeometry

Buongiorno a tutti...
A breve devo presentare un progetto di informatica che calcoli il volume di un oggetto composto da più solidi semplici e che lo visualizzi, il tutto su root.
Il codice da me scritto è :
Codice:
#include "TGeometry.h"
#include "TGeoManager.h"
#include "TGeoMatrix.h"
#include "TAttFill.h"
#include "TGeoBBox.h"
#include "TGeoCone.h"
#include "TGeoSphere.h"
#include "TGeoTube.h"
#include "TGeoCompositeShape.h"
#include "TGeoShape.h"
#include <string>
#include <iostream>
#include <cmath>
#include <vector>
using namespace std;

int volume2()
{
int numSolidi;
string solido;
double x, y,z,h,latox,latoy,x1,y1,z1,x2,y2,z2,rmin,rmax,hpar,hcil,Rmin,Rmax,themin,themax,phymin,phymax,rminbase,rmaxbase,rminsez,rmaxsez,hcon, x3,y3,z3;
double rotx, roty, rotz,rotx1,roty1,rotz1, rotx2,roty2,rotz2;

TGeoManager *volumes=new TGeoManager("volumes", "My volumes");

    TGeoMaterial *vacuum=new TGeoMaterial("vacuum",0,0,0);  
  
   TGeoMedium *Air=new TGeoMedium("Vacuum",0,vacuum);
 
  TGeoVolume *Top = gGeoManager->MakeBox("Top",Air, 10.,10.,10.);
  gGeoManager->SetTopVolume(Top);
 
  TGeoBBox *shape = new TGeoBBox("shape",0,0,0);
  TGeoCompositeShape *csf = new TGeoCompositeShape ("csf", "shape+shape");;

cout<<"Di quanti solidi semplici è costituito l'oggetto?"<<endl; 
cin>>numSolidi;
  if( cin.fail()){
      cout<<"I valori inseriti non sono validi, il programma verrà interrotto"<<endl;
      return 0;}

   for (int n=1; n<=numSolidi;n++){
   cout<<"Inserisci solido"<<n<<endl; 
   cin>>solido;
     if ( cin.fail()){
      cout<<"Non è il nome di un solido, il programma verrà interrotto"<<endl;
      return 0;           
      break;}

      if (solido == "parallelepipedo"){
        cout<<"CENTRO BASE"<<endl;
        cout<<"Coordinata x: "; cin>>x;
        cout<<"Coordinata y: ";cin>>y;
        cout<<"Coordinata z: ";cin>>z;
        cout<<"PARALLELEPIDO"<<endl;
        cout<<"Altezza parallelepipedo: ";cin>>hpar;
        cout<<"Lato x: ";cin>>latox;
        cout<<"Lato y: ";cin>>latoy;
        cout<<"Rotazione rispetto a z: "; cin>>rotz1;
        cout<<"Rotazione rispetto a x: "; cin>>rotx1;
        cout<<"Rotazione rispetto a y: "; cin>>roty1;
           if ( cin.fail()){
            cout<<"I valori inseriti non sono validi, il programma verrà interrotto"<<endl;
            return 0;           
            break;}
        TGeoBBox *Box = new TGeoBBox("volume",latox,latoy,hpar);
        TGeoRotation *rot= new TGeoRotation ("rot",rotx1,roty1,rotz1);
        TGeoCombiTrans *tr=new TGeoCombiTrans("tr",x,y,z,rot);
        tr->RegisterYourself();
        }
        
       else if (solido=="cilindro"){
        cout<<"Imposta valori richiesti"<<endl;
        cout<<"CENTRO BASE"<<endl;
        cout<<"Coordinata x: ";cin>>x1;
        cout<<"Coordinta y: ";cin>>y1;
        cout<<"Coordinata z: ";cin>>z1;
        cout<<"CILINDRO"<<endl;
        cout<<"Raggio minimo base: ";cin>>rmin;
        cout<<"Raggio massimo base: ";cin>>rmax;
        cout<<"Altezza cilindro: ";cin>>hcil;
        cout<<"Rotazione rispetto a z: "; cin>>rotz;
        cout<<"Rotazione rispetto a x: "; cin>>rotx;
        cout<<"Rotazione rispetto a y: "; cin>>roty;
           if ( cin.fail()){
            cout<<"I valori inseriti non sono validi, il programma verrà interrotto"<<endl;
            return 0;           
            break;}
        TGeoTube *Con = new TGeoTube("volume",rmin,rmax,hcil);
        TGeoRotation *rot= new TGeoRotation ("rot",rotx,roty,rotz);
        TGeoCombiTrans *tr=new TGeoCombiTrans("tr",x1,y1,z1,rot);
        tr->RegisterYourself();
        }

    
      else if (solido=="sfera"){
        cout <<"CENTRO SFERA"<<endl;
        cout<<"Coordinata x: ";cin>>x2;
        cout<<"Coordinata y: ";cin>>y2;
        cout<<"Coordinata z: ";cin>>z2;
        cout<<"SFERA"<<endl;  
        cout<<"Raggio minimo: ";cin>>Rmin;
        cout<<"Raggio massimo: ";cin>>Rmax;
        cout<<"Angolo phy minimo: ";cin>>phymin;
        cout<<"Angolo phy massimo: ";cin>>phymax;
        cout<<"Angolo theta minimo: ";cin>>themin;
        cout<<"Angolo theta massimo: ";cin>>themax;
          if ( cin.fail()){
           cout<<"I valori inseriti non sono validi, il programma verrà interrotto"<<endl;
           return 0;           
           break;}
        TGeoSphere *Sph = new TGeoSphere ("volume",Rmin,Rmax,phymin,phymax,themin,themax);
        TGeoRotation *rot= new TGeoRotation ("rot",0,0,0);
        TGeoCombiTrans *tr=new TGeoCombiTrans("tr",x2,y2,z2,rot);
        tr->RegisterYourself();
        }
  
       else if (solido=="cono"){
        cout<<"Imposta valori richiesti"<<endl;
        cout<<"altezza cono: "; cin>>hcon;
        cout<<"raggio minimo di base: "; cin>>rminbase;
        cout<<"raggio massimo base: "; cin>>rmaxbase;
        cout<<"raggio minimo sezione: "; cin>>rminbase;
        cout<<"raggio massimo sezione: "; cin>>rmaxsez;
        cout<<"CENTRO BASE"<<endl;
        cout<<"Coordinata x: ";cin>>x3;
        cout<<"Coordinata y: ";cin>>y3;
        cout<<"Coordinata z: ";cin>>z3;
        cout<<"Rotazione rispetto a z: "; cin>>rotz2;
        cout<<"Rotazione rispetto a x: "; cin>>rotx2;
        cout<<"Rotazione rispetto a y: "; cin>>roty2;
        
           if ( cin.fail()){
            cout<<"I valori inseriti non sono validi, il programma verrà interrotto"<<endl;
            return 0;           
            break;}
        TGeoCone *Con = new TGeoCone("volume",hcon, rminbase, rmaxbase, rminsez, rmaxsez);
        TGeoRotation *rot= new TGeoRotation ("rot",rotx2,roty2,rotz2);
        TGeoCombiTrans *tr=new TGeoCombiTrans("tr",x3,y3,z3,rot);
        tr->RegisterYourself();
        }
   
       else {
       cout<<"Solido non valido, verrà ignorato"<<endl;}
 
TGeoCompositeShape *csf = new TGeoCompositeShape("csf", "csf + volume:tr");
}
TGeoVolume *Comp = new TGeoVolume("Comp",csf);
Comp->SetLineColor(5);

Top->AddNode(Comp,1);
cout<<csf->Capacity()<<endl;
gGeoManager->CloseGeometry();
Top->Draw("ogl");}

Il problema è che la TGeoCompositeShape sembra vedermi solo il primo solido immesso.
Potete aiutarmi?

Ultima modifica di bettaskate89 : 21-09-2009 alle 16:11.
bettaskate89 è offline   Rispondi citando il messaggio o parte di esso
Old 21-09-2009, 15:21   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Due consigli:
1) per cortesia, se il codice pubblicato è identato, per non perdere l'identazione lo puoi racchiudere tra i tag "CODE" (tasto # nell'interfaccia di editing dei post);
2) A occhio per rispondere alla tua domanda uno dovrebbe essere pratico di ROOT. Nella fattiscpecie puoi aiutarti da sola, se qui non trovi nessun utente di questa libreria sviluppata dal CERN.
Eccoti un link utile alla Reference Documentation, che parla proprio delle classi che condividono nle nome il prefisso "TGeo".
In quella pagina trovi molte informazioni che ti saranno utili per il tuo progetto

@EDIT:
In particolare, eccoti la pagina che spiega cos'è una TGeoComposite (rappresentazione del risultato di un'operazione binaria di composizione tra shapes)
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 21-09-2009 alle 15:23.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 21-09-2009, 16:03   #3
bettaskate89
Junior Member
 
L'Avatar di bettaskate89
 
Iscritto dal: Sep 2009
Messaggi: 2
purtroppo ho già consultato le guide di root, ma non ho trovato risposta al mio dubbio...
Grazie comunque, immaginavo che non fosse facile trovare utenti di root!
bettaskate89 è offline   Rispondi citando il messaggio o parte di esso
Old 21-09-2009, 16:22   #4
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Attenzione, ti sto per dare il consiglio più banale del mondo

Questo link punta al forum interno del sito dedicato alla libreria:
1) fai una ricerca nel forum per vedere se trovi qualche topic già esistente che ti spiega il problema;
2) se il punto 1 non da i frutti sperati allora apri una nuova discussione e posta i tuoi dubbi e lo spezzone di codice.

__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
E-mail reset password di Instagram: la c...
La NASA ha discusso le problematiche del...
Il razzo spaziale NASA SLS e la capsula ...
Stazione Spaziale Internazionale: Crew-1...
Samsung Galaxy S26 Ultra: la ricarica de...
Apple ha un nuovo partner per la sua App...
Trenitalia introduce il prezzo dinamico ...
OnePlus non si ferma più: c'&egra...
DAZN sconta il piano Full per 6 mesi, se...
L'uso dell'IA nei giochi è cancer...
Meta punta sul nucleare USA per alimenta...
Le migliori offerte Amazon del weekend: ...
La crisi dell'hardware spinge i negozi g...
Apple Watch SE 3 scontato su Amazon: il ...
Robot aspirapolvere davvero scontati: si...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 00:36.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v