Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4VisCommandSceneAddScale Class Reference

#include <G4VisCommandsSceneAdd.hh>

+ Inheritance diagram for G4VisCommandSceneAddScale:

Public Member Functions

 G4VisCommandSceneAddScale ()
 
virtual ~G4VisCommandSceneAddScale ()
 
G4String GetCurrentValue (G4UIcommand *command)
 
void SetNewValue (G4UIcommand *command, G4String newValue)
 
- Public Member Functions inherited from G4VVisCommandScene
 G4VVisCommandScene ()
 
virtual ~G4VVisCommandScene ()
 
- Public Member Functions inherited from G4VVisCommand
 G4VVisCommand ()
 
virtual ~G4VVisCommand ()
 
- Public Member Functions inherited from G4UImessenger
 G4UImessenger ()=default
 
 G4UImessenger (const G4String &path, const G4String &dsc, G4bool commandsToBeBroadcasted=true)
 
virtual ~G4UImessenger ()
 
G4bool CommandsShouldBeInMaster () const
 

Additional Inherited Members

- Static Public Member Functions inherited from G4VVisCommand
static G4VisManagerGetVisManager ()
 
static void SetVisManager (G4VisManager *pVisManager)
 
static const G4ColourGetCurrentTextColour ()
 
- Protected Member Functions inherited from G4VVisCommandScene
G4String CurrentSceneName ()
 
- Protected Member Functions inherited from G4VVisCommand
void SetViewParameters (G4VViewer *viewer, const G4ViewParameters &viewParams)
 
void RefreshIfRequired (G4VViewer *viewer)
 
void InterpolateViews (G4VViewer *currentViewer, const std::vector< G4ViewParameters > &viewVector, const G4int nInterpolationPoints=50, const G4int waitTimePerPointmilliseconds=20, const G4String &exportString="")
 
void InterpolateToNewView (G4VViewer *currentViewer, const G4ViewParameters &oldVP, const G4ViewParameters &newVP, const G4int nInterpolationPoints=50, const G4int waitTimePerPointmilliseconds=20, const G4String &exportString="")
 
void Twinkle (G4VViewer *currentViewer, const G4ViewParameters &baseVP, const std::vector< std::vector< G4PhysicalVolumeModel::G4PhysicalVolumeNodeID > > &paths)
 
const G4StringConvertToColourGuidance ()
 
void ConvertToColour (G4Colour &colour, const G4String &redOrString, G4double green, G4double blue, G4double opacity)
 
G4bool ProvideValueOfUnit (const G4String &where, const G4String &unit, const G4String &category, G4double &value)
 
void CopyCameraParameters (G4ViewParameters &target, const G4ViewParameters &from)
 
void CheckSceneAndNotifyHandlers (G4Scene *=nullptr)
 
G4bool CheckView ()
 
void G4VisCommandsSceneAddUnsuccessful (G4VisManager::Verbosity verbosity)
 
void CopyGuidanceFrom (const G4UIcommand *fromCmd, G4UIcommand *toCmd, G4int startLine=0)
 
void CopyParametersFrom (const G4UIcommand *fromCmd, G4UIcommand *toCmd)
 
void DrawExtent (const G4VisExtent &)
 
- Protected Member Functions inherited from G4UImessenger
G4String ItoS (G4int i)
 
G4String LtoS (G4long l)
 
G4String DtoS (G4double a)
 
G4String BtoS (G4bool b)
 
G4int StoI (const G4String &s)
 
G4long StoL (const G4String &s)
 
G4double StoD (const G4String &s)
 
G4bool StoB (const G4String &s)
 
void AddUIcommand (G4UIcommand *newCommand)
 
void CreateDirectory (const G4String &path, const G4String &dsc, G4bool commandsToBeBroadcasted=true)
 
template<typename T>
T * CreateCommand (const G4String &cname, const G4String &dsc)
 
- Static Protected Member Functions inherited from G4VVisCommand
static G4String ConvertToString (G4double x, G4double y, const char *unitName)
 
static G4bool ConvertToDoublePair (const G4String &paramString, G4double &xval, G4double &yval)
 
- Protected Attributes inherited from G4UImessenger
G4UIdirectorybaseDir = nullptr
 
G4String baseDirName = ""
 
G4bool commandsShouldBeInMaster = false
 
- Static Protected Attributes inherited from G4VVisCommand
static G4VisManagerfpVisManager = nullptr
 
static G4int fCurrentArrow3DLineSegmentsPerCircle = 6
 
static G4Colour fCurrentColour = G4Colour::White()
 
static G4double fCurrentLineWidth = 1.
 
static G4Colour fCurrentTextColour = G4Colour::Blue()
 
static G4Text::Layout fCurrentTextLayout = G4Text::left
 
static G4double fCurrentTextSize = 12.
 
static G4PhysicalVolumeModel::TouchableProperties fCurrentTouchableProperties
 
static G4VisExtent fCurrentExtentForField
 
static std::vector< G4PhysicalVolumesSearchScene::FindingsfCurrrentPVFindingsForField
 
static G4bool fThereWasAViewer = false
 
static G4ViewParameters fExistingVP
 
static G4SceneTreeItem fExistingSceneTree
 

Detailed Description

Definition at line 380 of file G4VisCommandsSceneAdd.hh.

Constructor & Destructor Documentation

◆ G4VisCommandSceneAddScale()

G4VisCommandSceneAddScale::G4VisCommandSceneAddScale ( )

Definition at line 2154 of file G4VisCommandsSceneAdd.cc.

2154 {
2155 G4bool omitable;
2156 fpCommand = new G4UIcommand ("/vis/scene/add/scale", this);
2157 fpCommand -> SetGuidance
2158 ("Adds an annotated scale line to the current scene.");
2159 fpCommand -> SetGuidance
2160 ("If \"unit\" is \"auto\", length is roughly one tenth of the scene extent.");
2161 fpCommand -> SetGuidance
2162 ("If \"direction\" is \"auto\", scale is roughly in the plane of the current view.");
2163 fpCommand -> SetGuidance
2164 ("If \"placement\" is \"auto\", scale is placed at bottom left of current view."
2165 "\n Otherwise placed at (xmid,ymid,zmid).");
2166 fpCommand -> SetGuidance
2167 ("An annotated line in the specified direction with tick marks at the"
2168 "\nend. If autoPlacing is true it is required to be centred at the"
2169 "\nfront, right, bottom corner of the world space, comfortably outside"
2170 "\nthe existing bounding box/sphere so that existing objects do not"
2171 "\nobscure it. Otherwise it is required to be drawn with mid-point at"
2172 "\n(xmid, ymid, zmid)."
2173 "\n"
2174 "\nThe auto placing algorithm is (approx):"
2175 "\n x = xmin + (1 + comfort) * (xmax - xmin);"
2176 "\n y = ymin - comfort * (ymax - ymin);"
2177 "\n z = zmin + (1 + comfort) * (zmax - zmin);"
2178 "\n if direction == x then (x - length,y,z) to (x,y,z);"
2179 "\n if direction == y then (x,y,z) to (x,y + length,z);"
2180 "\n if direction == z then (x,y,z - length) to (x,y,z);"
2181 );
2182 G4UIparameter* parameter;
2183 parameter = new G4UIparameter ("length", 'd', omitable = true);
2184 parameter->SetDefaultValue (1.);
2185 fpCommand->SetParameter (parameter);
2186 parameter = new G4UIparameter ("unit", 's', omitable = true);
2187 parameter->SetDefaultValue ("auto");
2188 fpCommand->SetParameter (parameter);
2189 parameter = new G4UIparameter ("direction", 's', omitable = true);
2190 parameter->SetGuidance ("auto|x|y|z");
2191 parameter->SetDefaultValue ("auto");
2192 fpCommand->SetParameter (parameter);
2193 parameter = new G4UIparameter ("red", 'd', omitable = true);
2194 parameter->SetDefaultValue (1.);
2195 fpCommand->SetParameter (parameter);
2196 parameter = new G4UIparameter ("green", 'd', omitable = true);
2197 parameter->SetDefaultValue (0.);
2198 fpCommand->SetParameter (parameter);
2199 parameter = new G4UIparameter ("blue", 'd', omitable = true);
2200 parameter->SetDefaultValue (0.);
2201 fpCommand->SetParameter (parameter);
2202 parameter = new G4UIparameter ("placement", 's', omitable = true);
2203 parameter -> SetParameterCandidates("auto manual");
2204 parameter->SetDefaultValue ("auto");
2205 fpCommand->SetParameter (parameter);
2206 parameter = new G4UIparameter ("xmid", 'd', omitable = true);
2207 parameter->SetDefaultValue (0.);
2208 fpCommand->SetParameter (parameter);
2209 parameter = new G4UIparameter ("ymid", 'd', omitable = true);
2210 parameter->SetDefaultValue (0.);
2211 fpCommand->SetParameter (parameter);
2212 parameter = new G4UIparameter ("zmid", 'd', omitable = true);
2213 parameter->SetDefaultValue (0.);
2214 fpCommand->SetParameter (parameter);
2215 parameter = new G4UIparameter ("unit", 's', omitable = true);
2216 parameter->SetDefaultValue ("m");
2217 fpCommand->SetParameter (parameter);
2218}
bool G4bool
Definition G4Types.hh:86
void SetDefaultValue(const char *theDefaultValue)
void SetGuidance(const char *theGuidance)

◆ ~G4VisCommandSceneAddScale()

G4VisCommandSceneAddScale::~G4VisCommandSceneAddScale ( )
virtual

Definition at line 2220 of file G4VisCommandsSceneAdd.cc.

2220 {
2221 delete fpCommand;
2222}

Member Function Documentation

◆ GetCurrentValue()

G4String G4VisCommandSceneAddScale::GetCurrentValue ( G4UIcommand * command)
virtual

Reimplemented from G4UImessenger.

Definition at line 2224 of file G4VisCommandsSceneAdd.cc.

2224 {
2225 return "";
2226}

◆ SetNewValue()

void G4VisCommandSceneAddScale::SetNewValue ( G4UIcommand * command,
G4String newValue )
virtual

Reimplemented from G4UImessenger.

Definition at line 2228 of file G4VisCommandsSceneAdd.cc.

2228 {
2229
2230 G4VisManager::Verbosity verbosity = fpVisManager->GetVerbosity();
2231 G4bool warn = verbosity >= G4VisManager::warnings;
2232
2233 G4Scene* pScene = fpVisManager->GetCurrentScene();
2234 if (!pScene) {
2235 if (verbosity >= G4VisManager::errors) {
2236 G4warn << "ERROR: No current scene. Please create one." << G4endl;
2237 }
2238 return;
2239 } else {
2240 if (pScene->GetExtent().GetExtentRadius() <= 0.) {
2241 if (verbosity >= G4VisManager::errors) {
2242 G4warn
2243 << "ERROR: Scene has no extent. Add volumes or use \"/vis/scene/add/extent\"."
2244 << G4endl;
2245 }
2246 return;
2247 }
2248 }
2249
2250 G4double userLength, red, green, blue, xmid, ymid, zmid;
2251 G4String userLengthUnit, direction, placement, positionUnit;
2252 std::istringstream is (newValue);
2253 is >> userLength >> userLengthUnit >> direction
2254 >> red >> green >> blue
2255 >> placement
2256 >> xmid >> ymid >> zmid >> positionUnit;
2257
2258 G4double length = userLength;
2259 const G4VisExtent& sceneExtent = pScene->GetExtent(); // Existing extent.
2260 if (userLengthUnit == "auto") {
2261 const G4double lengthMax = 0.5 * sceneExtent.GetExtentRadius();
2262 const G4double intLog10Length = std::floor(std::log10(lengthMax));
2263 length = std::pow(10,intLog10Length);
2264 if (5.*length < lengthMax) length *= 5.;
2265 else if (2.*length < lengthMax) length *= 2.;
2266 } else {
2267 length *= G4UIcommand::ValueOf(userLengthUnit);
2268 }
2269 G4String annotation = G4BestUnit(length,"Length");
2270
2271 G4double unit = G4UIcommand::ValueOf(positionUnit);
2272 xmid *= unit; ymid *= unit; zmid *= unit;
2273
2274 Scale::Direction scaleDirection (Scale::x);
2275 if (direction[0] == 'y') scaleDirection = Scale::y;
2276 if (direction[0] == 'z') scaleDirection = Scale::z;
2277
2278 G4VViewer* pViewer = fpVisManager->GetCurrentViewer();
2279 if (!pViewer) {
2280 if (verbosity >= G4VisManager::errors) {
2281 G4warn <<
2282 "ERROR: G4VisCommandSceneAddScale::SetNewValue: no viewer."
2283 "\n Auto direction needs a viewer."
2284 << G4endl;
2285 }
2286 return;
2287 }
2288
2289 const G4Vector3D& vp =
2291 const G4Vector3D& up =
2292 pViewer->GetViewParameters().GetUpVector();
2293
2294 if (direction == "auto") { // Takes cue from viewer.
2295 if (std::abs(vp.x()) > std::abs(vp.y()) &&
2296 std::abs(vp.x()) > std::abs(vp.z())) { // x viewpoint
2297 if (std::abs(up.y()) > std::abs(up.z())) scaleDirection = Scale::z;
2298 else scaleDirection = Scale::y;
2299 }
2300 else if (std::abs(vp.y()) > std::abs(vp.x()) &&
2301 std::abs(vp.y()) > std::abs(vp.z())) { // y viewpoint
2302 if (std::abs(up.x()) > std::abs(up.z())) scaleDirection = Scale::z;
2303 else scaleDirection = Scale::x;
2304 }
2305 else if (std::abs(vp.z()) > std::abs(vp.x()) &&
2306 std::abs(vp.z()) > std::abs(vp.y())) { // z viewpoint
2307 if (std::abs(up.y()) > std::abs(up.x())) scaleDirection = Scale::x;
2308 else scaleDirection = Scale::y;
2309 }
2310 }
2311
2312 G4bool autoPlacing = false; if (placement == "auto") autoPlacing = true;
2313 // Parameters read and interpreted.
2314
2315 // Useful constants, etc...
2316 const G4double halfLength(length / 2.);
2317 const G4double comfort(0.01); // 0.15 seems too big. 0.05 might be better.
2318 const G4double freeLengthFraction (1. + 2. * comfort);
2319
2320 const G4double xmin = sceneExtent.GetXmin();
2321 const G4double xmax = sceneExtent.GetXmax();
2322 const G4double ymin = sceneExtent.GetYmin();
2323 const G4double ymax = sceneExtent.GetYmax();
2324 const G4double zmin = sceneExtent.GetZmin();
2325 const G4double zmax = sceneExtent.GetZmax();
2326
2327 // Test existing extent and issue warnings...
2328 G4bool worried = false;
2329 if (sceneExtent.GetExtentRadius() == 0) {
2330 worried = true;
2331 if (verbosity >= G4VisManager::warnings) {
2332 G4warn <<
2333 "WARNING: Existing scene does not yet have any extent."
2334 "\n Maybe you have not yet added any geometrical object."
2335 << G4endl;
2336 }
2337 }
2338
2339 // Test existing scene for room...
2340 G4bool room = true;
2341 switch (scaleDirection) {
2342 case Scale::x:
2343 if (freeLengthFraction * (xmax - xmin) < length) room = false;
2344 break;
2345 case Scale::y:
2346 if (freeLengthFraction * (ymax - ymin) < length) room = false;
2347 break;
2348 case Scale::z:
2349 if (freeLengthFraction * (zmax - zmin) < length) room = false;
2350 break;
2351 }
2352 if (!room) {
2353 worried = true;
2354 if (verbosity >= G4VisManager::warnings) {
2355 G4warn <<
2356 "WARNING: Not enough room in existing scene. Maybe scale is too long."
2357 << G4endl;
2358 }
2359 }
2360 if (worried) {
2361 if (verbosity >= G4VisManager::warnings) {
2362 G4warn <<
2363 "WARNING: The scale you have asked for is bigger than the existing"
2364 "\n scene. Maybe you have added it too soon. It is recommended that"
2365 "\n you add the scale last so that it can be correctly auto-positioned"
2366 "\n so as not to be obscured by any existing object and so that the"
2367 "\n view parameters can be correctly recalculated."
2368 << G4endl;
2369 }
2370 }
2371
2372 // Now figure out the extent...
2373 //
2374 // This creates a representation of annotated line in the specified
2375 // direction with tick marks at the end. If autoPlacing is true it
2376 // is required to be centred at the front, right, bottom corner of
2377 // the world space, comfortably outside the existing bounding
2378 // box/sphere so that existing objects do not obscure it. Otherwise
2379 // it is required to be drawn with mid-point at (xmid, ymid, zmid).
2380 //
2381 // The auto placing algorithm might be:
2382 // x = xmin + (1 + comfort) * (xmax - xmin)
2383 // y = ymin - comfort * (ymax - ymin)
2384 // z = zmin + (1 + comfort) * (zmax - zmin)
2385 // if direction == x then (x - length,y,z) to (x,y,z)
2386 // if direction == y then (x,y,z) to (x,y + length,z)
2387 // if direction == z then (x,y,z - length) to (x,y,z)
2388 //
2389 // Implement this in two parts. Here, use the scale's extent to
2390 // "expand" the scene's extent. Then rendering - in
2391 // G4VSceneHandler::AddPrimitive(const G4Scale&) - simply has to
2392 // ensure it's within the new extent.
2393 //
2394
2395 G4double sxmid(xmid), symid(ymid), szmid(zmid);
2396 if (autoPlacing) {
2397 // Aim to place at bottom right of screen in current view.
2398 // Give some comfort zone.
2399 const G4double xComfort = comfort * (xmax - xmin);
2400 const G4double yComfort = comfort * (ymax - ymin);
2401 const G4double zComfort = comfort * (zmax - zmin);
2402 switch (scaleDirection) {
2403 case Scale::x:
2404 if (vp.z() > 0.) {
2405 sxmid = xmax + xComfort;
2406 symid = ymin - yComfort;
2407 szmid = zmin - zComfort;
2408 } else {
2409 sxmid = xmin - xComfort;
2410 symid = ymin - yComfort;
2411 szmid = zmax + zComfort;
2412 }
2413 break;
2414 case Scale::y:
2415 if (vp.x() > 0.) {
2416 sxmid = xmin - xComfort;
2417 symid = ymax + yComfort;
2418 szmid = zmin - zComfort;
2419 } else {
2420 sxmid = xmax + xComfort;
2421 symid = ymin - yComfort;
2422 szmid = zmin - zComfort;
2423 }
2424 break;
2425 case Scale::z:
2426 if (vp.x() > 0.) {
2427 sxmid = xmax + xComfort;
2428 symid = ymin - yComfort;
2429 szmid = zmax + zComfort;
2430 } else {
2431 sxmid = xmin - xComfort;
2432 symid = ymin - yComfort;
2433 szmid = zmax + zComfort;
2434 }
2435 break;
2436 }
2437 }
2438
2439 G4Transform3D transform;
2440 const G4double h = halfLength;
2441 const G4double t = h/5.;
2442 G4VisExtent scaleExtent(-h,h,-t,t,-t,t);
2443 switch (scaleDirection) {
2444 case Scale::x:
2445 break;
2446 case Scale::y:
2447 transform = G4RotateZ3D(halfpi);
2448 break;
2449 case Scale::z:
2450 transform = G4RotateY3D(halfpi);
2451 break;
2452 }
2453 transform = G4Translate3D(sxmid,symid,szmid) * transform;
2454 scaleExtent = scaleExtent.Transform(transform);
2455
2456 G4Colour colour(red, green, blue);
2457 if (direction == "auto") {
2458 switch (scaleDirection) {
2459 case Scale::x:
2460 colour = G4Colour::Red();
2461 break;
2462 case Scale::y:
2463 colour = G4Colour::Green();
2464 break;
2465 case Scale::z:
2466 colour = G4Colour::Blue();
2467 break;
2468 }
2469 }
2470 G4VisAttributes visAttr(colour);
2471
2472 Scale* scale = new Scale
2473 (visAttr, length, transform,
2474 annotation, fCurrentTextSize, colour);
2475 G4VModel* model = new G4CallbackModel<Scale>(scale);
2476 model->SetType("Scale");
2477 model->SetGlobalTag("Scale");
2478 model->SetGlobalDescription("Scale: " + newValue);
2479 model->SetExtent(scaleExtent);
2480
2481 const G4String& currentSceneName = pScene -> GetName ();
2482 G4bool successful = pScene -> AddRunDurationModel (model, warn);
2483 if (successful) {
2484 if (verbosity >= G4VisManager::confirmations) {
2485 G4cout << "Scale of " << annotation
2486 << " added to scene \"" << currentSceneName << "\".";
2487 if (verbosity >= G4VisManager::parameters) {
2488 G4cout << "\n with extent " << scaleExtent
2489 << "\n at " << transform.getRotation()
2490 << " " << transform.getTranslation();
2491 }
2492 G4cout << G4endl;
2493 }
2494 }
2495 else G4VisCommandsSceneAddUnsuccessful(verbosity);
2496
2498}
#define G4warn
Definition G4Scene.cc:41
#define G4BestUnit(a, b)
HepGeom::Transform3D G4Transform3D
HepGeom::RotateZ3D G4RotateZ3D
HepGeom::RotateY3D G4RotateY3D
HepGeom::Translate3D G4Translate3D
double G4double
Definition G4Types.hh:83
HepGeom::Vector3D< G4double > G4Vector3D
Definition G4Vector3D.hh:34
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
static G4Colour Green()
Definition G4Colour.hh:180
static G4Colour Red()
Definition G4Colour.hh:179
static G4Colour Blue()
Definition G4Colour.hh:181
const G4VisExtent & GetExtent() const
static G4double ValueOf(const char *unitName)
void SetType(const G4String &)
void SetGlobalDescription(const G4String &)
void SetGlobalTag(const G4String &)
void SetExtent(const G4VisExtent &)
const G4ViewParameters & GetViewParameters() const
static G4double fCurrentTextSize
void G4VisCommandsSceneAddUnsuccessful(G4VisManager::Verbosity verbosity)
void CheckSceneAndNotifyHandlers(G4Scene *=nullptr)
static G4VisManager * fpVisManager
const G4Vector3D & GetViewpointDirection() const
const G4Vector3D & GetUpVector() const
G4double GetYmin() const
G4double GetXmax() const
G4double GetExtentRadius() const
G4double GetYmax() const
G4double GetZmax() const
G4double GetZmin() const
G4double GetXmin() const
CLHEP::HepRotation getRotation() const
CLHEP::Hep3Vector getTranslation() const

The documentation for this class was generated from the following files: