1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-26 10:19:45 +03:00
occt/src/Message/Message_ProgressScale.hxx
abv 42cf5bc1ca 0024002: Overall code and build procedure refactoring -- automatic
Automatic upgrade of OCCT code by command "occt_upgrade . -nocdl":
- WOK-generated header files from inc and sources from drv are moved to src
- CDL files removed
- All packages are converted to nocdlpack
2015-07-12 07:42:38 +03:00

134 lines
3.6 KiB
C++

// Created on: 2002-02-20
// Created by: Andrey BETENEV
// Copyright (c) 2002-2014 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and/or modify it under
// the terms of the GNU Lesser General Public License version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.
#ifndef _Message_ProgressScale_HeaderFile
#define _Message_ProgressScale_HeaderFile
#include <Standard.hxx>
#include <Standard_DefineAlloc.hxx>
#include <Standard_Handle.hxx>
#include <Standard_Real.hxx>
#include <Standard_Boolean.hxx>
#include <Standard_CString.hxx>
class TCollection_HAsciiString;
//! Internal data structure for scale in ProgressIndicator
//!
//! Basically it defines three things:
//! - name that can be used for generating user messages
//! - limits and characteristics of the current scale,
//! along with derived coefficients to map it into basic scale [0-1]
//! - methods for conversion of values from current scale
//! to basic one and back
//!
//! NOTE: There is no special protection against bad input data
//! like min > max etc. except cases when it can cause exception
class Message_ProgressScale
{
public:
DEFINE_STANDARD_ALLOC
//! Creates scale ranged from 0 to 100 with step 1
Standard_EXPORT Message_ProgressScale();
void SetName (const Standard_CString theName);
//! Sets scale name
void SetName (const Handle(TCollection_HAsciiString)& theName);
//! Gets scale name
//! Name may be Null handle if not set
Handle(TCollection_HAsciiString) GetName() const;
//! Sets minimum value of scale
void SetMin (const Standard_Real theMin);
//! Gets minimum value of scale
Standard_Real GetMin() const;
//! Sets minimum value of scale
void SetMax (const Standard_Real theMax);
//! Gets minimum value of scale
Standard_Real GetMax() const;
//! Set both min and max
void SetRange (const Standard_Real min, const Standard_Real max);
//! Sets default step
void SetStep (const Standard_Real theStep);
//! Gets default step
Standard_Real GetStep() const;
//! Sets flag for infinite scale
void SetInfinite (const Standard_Boolean theInfinite = Standard_True);
//! Gets flag for infinite scale
Standard_Boolean GetInfinite() const;
//! Set all scale parameters
void SetScale (const Standard_Real min, const Standard_Real max, const Standard_Real step, const Standard_Boolean theInfinite = Standard_True);
//! Defines span occupied by the scale on the basis scale
void SetSpan (const Standard_Real first, const Standard_Real last);
Standard_Real GetFirst() const;
//! Return information on span occupied by the scale on the base scale
Standard_Real GetLast() const;
Standard_EXPORT Standard_Real LocalToBase (const Standard_Real val) const;
//! Convert value from this scale to base one and back
Standard_EXPORT Standard_Real BaseToLocal (const Standard_Real val) const;
protected:
private:
Handle(TCollection_HAsciiString) myName;
Standard_Real myMin;
Standard_Real myMax;
Standard_Real myStep;
Standard_Boolean myInfinite;
Standard_Real myFirst;
Standard_Real myLast;
};
#include <Message_ProgressScale.lxx>
#endif // _Message_ProgressScale_HeaderFile