1 // Copyright (c) 1995-1999 Matra Datavision
2 // Copyright (c) 1999-2012 OPEN CASCADE SAS
4 // The content of this file is subject to the Open CASCADE Technology Public
5 // License Version 6.5 (the "License"). You may not use the content of this file
6 // except in compliance with the License. Please obtain a copy of the License
7 // at http://www.opencascade.org and read it completely before using this file.
9 // The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
10 // main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
12 // The Original Code and all software distributed under the License is
13 // distributed on an "AS IS" basis, without warranty of any kind, and the
14 // Initial Developer hereby disclaims all such warranties, including without
15 // limitation, any warranties of merchantability, fitness for a particular
16 // purpose or non-infringement. Please see the License for the specific terms
17 // and conditions governing the rights and limitations under the License.
19 #include <Graphic2d_VectorialMarker.ixx>
21 Graphic2d_VectorialMarker::Graphic2d_VectorialMarker (const Handle(Graphic2d_GraphicObject)& aGraphicObject, const Quantity_Length aXPosition, const Quantity_Length aYPosition)
23 :Graphic2d_Line (aGraphicObject),
24 myXPosition (Standard_ShortReal (aXPosition)),
25 myYPosition (Standard_ShortReal (aYPosition)) {
27 SetFamily(Graphic2d_TOP_MARKER);
30 void Graphic2d_VectorialMarker::SetPosition (const Quantity_Length aXPosition, const Quantity_Length aYPosition) {
32 myXPosition = Standard_ShortReal (aXPosition);
33 myYPosition = Standard_ShortReal (aYPosition);
38 Quantity_Length Graphic2d_VectorialMarker::XPosition () const {
40 Standard_Real X = Standard_Real (myXPosition);
41 Standard_Real Y = Standard_Real (myYPosition);
43 if (myGOPtr->IsTransformed ()) {
44 gp_GTrsf2d aTrsf = myGOPtr->Transform ();
45 aTrsf.Transforms (X, Y);
48 return Quantity_Length (X);
52 Quantity_Length Graphic2d_VectorialMarker::YPosition () const {
54 Standard_Real X = Standard_Real (myXPosition);
55 Standard_Real Y = Standard_Real (myYPosition);
57 if (myGOPtr->IsTransformed ()) {
58 gp_GTrsf2d aTrsf = myGOPtr->Transform ();
59 aTrsf.Transforms (X, Y);
62 return Quantity_Length (Y);