draftguitools.gui_snapper.Snapper Class Reference

Public Member Functions

def addHoldPoint (self)
 
def constrain (self, point, basepoint=None, axis=None)
 
def cstr (self, lastpoint, constrain, point)
 
def cycleSnapObject (self)
 
def get_snap_toolbar (self)
 
def getApparentPoint (self, x, y)
 
def getPerpendicular (self, edge, pt)
 
def getPoint (self, last=None, callback=None, movecallback=None, extradlg=None, title=None, mode="point")
 
def getScreenDist (self, dist, cursor)
 
def hide (self)
 
def init_active_snaps (self)
 
def init_draft_snap_buttons (self, commands, context, button_suffix)
 
def init_grid_button (self, context)
 
def isEnabled (self, snap)
 
def makeSnapToolBar (self)
 
def off (self, hideSnapBar=False)
 
def restack (self)
 
def restore_snap_buttons_state (self, toolbar, button_suffix)
 
def save_snap_state (self)
 
def setAngle (self, delta=None)
 
def setArchDims (self, p1, p2)
 
def setCursor (self, mode=None)
 
def setGrid (self)
 
def setSelectMode (self, mode)
 
def setTrackers (self)
 
def show (self)
 
def showradius (self)
 
def snap (self, screenpos, lastpoint=None, active=True, constrain=False, noTracker=False)
 
def snapToAngles (self, shape)
 
def snapToCenter (self, shape)
 
def snapToCrossExtensions (self, point)
 
def snapToDim (self, obj)
 
def snapToElines (self, e1, e2)
 
def snapToEndpoints (self, shape)
 
def snapToExtensions (self, point, last, constrain, eline)
 
def snapToExtOrtho (self, last, constrain, eline)
 
def snapToExtPerpendicular (self, last)
 
def snapToFace (self, shape)
 
def snapToGrid (self, point)
 
def snapToHold (self, point)
 
def snapToIntersection (self, shape)
 
def snapToMidpoint (self, shape)
 
def snapToObject (self, lastpoint, active, constrain, eline, point, oldActive)
 
def snapToOrtho (self, shape, last, constrain)
 
def snapToPerpendicular (self, shape, last)
 
def snapToPolar (self, point, last)
 
def snapToPolygon (self, obj)
 
def snapToSpecials (self, obj, lastpoint=None, eline=None)
 
def snapToVertex (self, info, active=False)
 
def toggle_snap (self, snap, set_to=None)
 
def toggleGrid (self)
 
def toWP (self, point)
 
def unconstrain (self)
 

Public Attributes

 active
 
 active_snaps
 
 activeview
 
 affinity
 
 basepoint
 
 callbackClick
 
 callbackMove
 
 constrainLine
 
 constraintAxis
 
 cursorMode
 
 cursors
 
 dim1
 
 dim2
 
 extLine
 
 extLine2
 
 forceGridOff
 
 grid
 
 holdPoints
 
 holdTracker
 
 lastExtensions
 
 lastObj
 
 lastSnappedObject
 
 mask
 
 maxEdges
 
 mk
 
 polarAngles
 
 pt
 
 radius
 
 radiusTracker
 
 running
 
 selectMode
 
 snapInfo
 
 snapObjectIndex
 
 snaps
 
 snapStyle
 
 spoint
 
 toolbar
 
 tracker
 
 trackers
 
 trackLine
 
 ui
 
 view
 

Detailed Description

Classes to manage snapping in Draft and Arch.

The Snapper objects contains all the functionality used by draft
and arch module to manage object snapping. It is responsible for
finding snap points and displaying snap markers. Usually You
only need to invoke it's snap() function, all the rest is taken
care of.

3 functions are useful for the scriptwriter: snap(), constrain()
or getPoint() which is an all-in-one combo.

The individual snapToXXX() functions return a snap definition in
the form [real_point,marker_type,visual_point], and are not
meant to be used directly, they are all called when necessary by
the general snap() function.

The Snapper lives inside FreeCADGui once the Draft module has been
loaded.

Member Function Documentation

◆ addHoldPoint()

def draftguitools.gui_snapper.Snapper.addHoldPoint (   self)

◆ constrain()

def draftguitools.gui_snapper.Snapper.constrain (   self,
  point,
  basepoint = None,
  axis = None 
)
Return a constrained point.

constrain(point,basepoint=None,axis=None: Returns a
constrained point. Axis can be "x","y" or "z" or a custom vector. If None,
the closest working plane axis will be picked.
Basepoint is the base point used to figure out from where the point
must be constrained. If no basepoint is given, the current point is
used as basepoint.

References draftguitools.gui_snapper.Snapper.affinity, draftguitools.gui_snapper.Snapper.basepoint, draftguitools.gui_snapper.Snapper.constrainLine, draftguitools.gui_snapper.Snapper.constraintAxis, draftguitools.gui_snapper.Snapper.mask, DraftGui.DraftToolBar.mask, draftguitools.gui_snapper.Snapper.off(), DraftVecUtils.project(), and draftguitools.gui_snapper.Snapper.snapStyle.

Referenced by draftguitools.gui_snapper.Snapper.cstr().

◆ cstr()

◆ cycleSnapObject()

def draftguitools.gui_snapper.Snapper.cycleSnapObject (   self)
Increse the index of the snap object by one.

References draftguitools.gui_snapper.Snapper.snapObjectIndex.

◆ get_snap_toolbar()

def draftguitools.gui_snapper.Snapper.get_snap_toolbar (   self)
Returns snap toolbar object.

References Gui.getMainWindow().

Referenced by draftguitools.gui_snapper.Snapper.show().

◆ getApparentPoint()

def draftguitools.gui_snapper.Snapper.getApparentPoint (   self,
  x,
  y 
)
Return a 3D point, projected on the current working plane.

References draftguitools.gui_snapper.Snapper.mask, and DraftGui.DraftToolBar.mask.

◆ getPerpendicular()

def draftguitools.gui_snapper.Snapper.getPerpendicular (   self,
  edge,
  pt 
)

◆ getPoint()

def draftguitools.gui_snapper.Snapper.getPoint (   self,
  last = None,
  callback = None,
  movecallback = None,
  extradlg = None,
  title = None,
  mode = "point" 
)
Get a 3D point from the screen.

getPoint([last],[callback],[movecallback],[extradlg],[title]):
gets a 3D point from the screen. You can provide an existing point,
in that case additional snap options and a tracker are available.
You can also pass a function as callback, which will get called
with the resulting point as argument, when a point is clicked,
and optionally another callback which gets called when
the mouse is moved.

If the operation gets cancelled (the user pressed Escape),
no point is returned.

Example:

def cb(point):
    if point:
print "got a 3D point: ",point

Gui.Snapper.getPoint(callback=cb)

If the callback function accepts more than one argument,
it will also receive the last snapped object. Finally, a qt widget
can be passed as an extra taskbox.
title is the title of the point task box mode is the dialog box
you want (default is point, you can also use wire and line)

If getPoint() is invoked without any argument, nothing is done
but the callbacks are removed, so it can be used as a cancel function.

◆ getScreenDist()

def draftguitools.gui_snapper.Snapper.getScreenDist (   self,
  dist,
  cursor 
)
Return a distance in 3D space from a screen pixels distance.

Referenced by draftguitools.gui_snapper.Snapper.showradius().

◆ hide()

◆ init_active_snaps()

def draftguitools.gui_snapper.Snapper.init_active_snaps (   self)
set self.active_snaps according to user prefs

◆ init_draft_snap_buttons()

def draftguitools.gui_snapper.Snapper.init_draft_snap_buttons (   self,
  commands,
  context,
  button_suffix 
)
Init Draft Snap toolbar buttons.

Parameters:
commands        Snap command list,
        use: get_draft_snap_commands():
context         The toolbar or action group the buttons have 
        to be added to    
button_suffix   The suffix that have to be applied to the command name
        to define the button name

References draftguitools.gui_snapper.Snapper.init_grid_button(), and draftguitools.gui_snapper.Snapper.toolbar.

◆ init_grid_button()

def draftguitools.gui_snapper.Snapper.init_grid_button (   self,
  context 
)
Add grid button to the given toolbar

Referenced by draftguitools.gui_snapper.Snapper.init_draft_snap_buttons().

◆ isEnabled()

◆ makeSnapToolBar()

def draftguitools.gui_snapper.Snapper.makeSnapToolBar (   self)
Build the Snap toolbar.

References Gui.getMainWindow().

Referenced by draftguitools.gui_snapper.Snapper.show().

◆ off()

def draftguitools.gui_snapper.Snapper.off (   self,
  hideSnapBar = False 
)
Finish snapping.

References draftguitools.gui_snapper.Snapper.dim1, draftguitools.gui_snapper.Snapper.dim2, draftguitools.gui_snapper.Snapper.extLine, draftguitools.gui_snapper.Snapper.extLine2, FaceQuadStruct::Side.grid, draftguitools.gui_snapper.Snapper.grid, ArchCutPlane._CutPlaneTaskPanel.grid, ArchAxis._AxisTaskPanel.grid, ArchPrecast._PrecastTaskPanel.grid, ArchRoof._RoofTaskPanel.grid, ArchAxis.AxisSystemTaskPanel.grid, ArchWindow._ArchWindowTaskPanel.grid, ArchPrecast._DentsTaskPanel.grid, ArchSectionPlane.SectionPlaneTaskPanel.grid, ArchComponent.ComponentTaskPanel.grid, DraftGui.FacebinderTaskPanel.grid, draftguitools.gui_snapper.Snapper.hide(), draftguitools.gui_snapper.Snapper.holdPoints, draftguitools.gui_snapper.Snapper.holdTracker, draftguitools.gui_snapper.Snapper.mask, DraftGui.DraftToolBar.mask, draftguitools.gui_snapper.Snapper.radius, DraftGui.DraftToolBar.radius, draftguitools.gui_snapper.Snapper.radiusTracker, draftguitools.gui_line_add_delete.AddPoint.running, ArchNesting.Nester.running, draftguitools.gui_offset.Offset.running, draftguitools.gui_line_add_delete.DelPoint.running, draftguitools.gui_snapper.Snapper.running, App::PropertyExpressionEngine.running, draftguitools.gui_edit.Edit.running, Gui::GUISingleApplication::Private.running, Gui::PythonDebuggerP.running, draftguitools.gui_snapper.Snapper.selectMode, draftguitools.gui_snapper.Snapper.setCursor(), draftguitools.gui_snapper.Snapper.toolbar, draftguitools.gui_snapper.Snapper.tracker, ArchPanel.CommandPanel.tracker, ArchWindow._CommandWindow.tracker, ArchStructure._CommandStructure.tracker, ArchWall._CommandWall.tracker, draftguitools.gui_arcs.Arc_3Points.tracker, draftguitools.gui_snapper.Snapper.trackLine, and draftguitools.gui_snapper.Snapper.unconstrain().

Referenced by draftguitools.gui_snapper.Snapper.constrain(), draftguitools.gui_snapper.Snapper.setSelectMode(), and draftguitools.gui_snapper.Snapper.unconstrain().

◆ restack()

def draftguitools.gui_snapper.Snapper.restack (   self)
Lower the grid tracker so it doesn't obscure other objects.

References FaceQuadStruct::Side.grid, draftguitools.gui_snapper.Snapper.grid, ArchCutPlane._CutPlaneTaskPanel.grid, ArchAxis._AxisTaskPanel.grid, ArchPrecast._PrecastTaskPanel.grid, ArchRoof._RoofTaskPanel.grid, ArchAxis.AxisSystemTaskPanel.grid, ArchWindow._ArchWindowTaskPanel.grid, ArchPrecast._DentsTaskPanel.grid, ArchSectionPlane.SectionPlaneTaskPanel.grid, ArchComponent.ComponentTaskPanel.grid, and DraftGui.FacebinderTaskPanel.grid.

◆ restore_snap_buttons_state()

def draftguitools.gui_snapper.Snapper.restore_snap_buttons_state (   self,
  toolbar,
  button_suffix 
)
Restore toolbar button's checked state according to 
"snapModes" saved in preferences

◆ save_snap_state()

def draftguitools.gui_snapper.Snapper.save_snap_state (   self)
Save snap state to user preferences to be restored in next session.

References draftguitools.gui_snapper.Snapper.active_snaps, and draftguitools.gui_snapper.Snapper.snaps.

Referenced by draftguitools.gui_snapper.Snapper.toggle_snap().

◆ setAngle()

def draftguitools.gui_snapper.Snapper.setAngle (   self,
  delta = None 
)

◆ setArchDims()

def draftguitools.gui_snapper.Snapper.setArchDims (   self,
  p1,
  p2 
)

◆ setCursor()

◆ setGrid()

def draftguitools.gui_snapper.Snapper.setGrid (   self)
Set the grid, if visible.

References draftguitools.gui_snapper.Snapper.forceGridOff, FaceQuadStruct::Side.grid, draftguitools.gui_snapper.Snapper.grid, ArchCutPlane._CutPlaneTaskPanel.grid, ArchAxis._AxisTaskPanel.grid, ArchPrecast._PrecastTaskPanel.grid, ArchRoof._RoofTaskPanel.grid, ArchAxis.AxisSystemTaskPanel.grid, ArchWindow._ArchWindowTaskPanel.grid, ArchPrecast._DentsTaskPanel.grid, ArchSectionPlane.SectionPlaneTaskPanel.grid, ArchComponent.ComponentTaskPanel.grid, DraftGui.FacebinderTaskPanel.grid, draftguitools.gui_edit.Edit.setTrackers(), and draftguitools.gui_snapper.Snapper.setTrackers().

◆ setSelectMode()

def draftguitools.gui_snapper.Snapper.setSelectMode (   self,
  mode 
)

◆ setTrackers()

◆ show()

◆ showradius()

def draftguitools.gui_snapper.Snapper.showradius (   self)

◆ snap()

def draftguitools.gui_snapper.Snapper.snap (   self,
  screenpos,
  lastpoint = None,
  active = True,
  constrain = False,
  noTracker = False 
)
Return a snapped point from the given (x, y) screen position.

snap(screenpos,lastpoint=None,active=True,constrain=False,
noTracker=False): returns a snapped point from the given
(x,y) screenpos (the position of the mouse cursor), active is to
activate active point snapping or not (passive),
lastpoint is an optional other point used to draw an
imaginary segment and get additional snap locations. Constrain can
be True to constrain the point against the closest working plane axis.
Screenpos can be a list, a tuple or a coin.SbVec2s object.
If noTracker is True, the tracking line is not displayed.

References draftguitools.gui_line_add_delete.AddPoint.running, ArchNesting.Nester.running, draftguitools.gui_offset.Offset.running, draftguitools.gui_line_add_delete.DelPoint.running, draftguitools.gui_snapper.Snapper.running, App::PropertyExpressionEngine.running, draftguitools.gui_edit.Edit.running, Gui::GUISingleApplication::Private.running, and Gui::PythonDebuggerP.running.

◆ snapToAngles()

def draftguitools.gui_snapper.Snapper.snapToAngles (   self,
  shape 
)

◆ snapToCenter()

def draftguitools.gui_snapper.Snapper.snapToCenter (   self,
  shape 
)

◆ snapToCrossExtensions()

◆ snapToDim()

def draftguitools.gui_snapper.Snapper.snapToDim (   self,
  obj 
)

◆ snapToElines()

def draftguitools.gui_snapper.Snapper.snapToElines (   self,
  e1,
  e2 
)

◆ snapToEndpoints()

def draftguitools.gui_snapper.Snapper.snapToEndpoints (   self,
  shape 
)

◆ snapToExtensions()

◆ snapToExtOrtho()

def draftguitools.gui_snapper.Snapper.snapToExtOrtho (   self,
  last,
  constrain,
  eline 
)

◆ snapToExtPerpendicular()

def draftguitools.gui_snapper.Snapper.snapToExtPerpendicular (   self,
  last 
)

◆ snapToFace()

def draftguitools.gui_snapper.Snapper.snapToFace (   self,
  shape 
)

◆ snapToGrid()

def draftguitools.gui_snapper.Snapper.snapToGrid (   self,
  point 
)
Return a grid snap point if available.

References FaceQuadStruct::Side.grid, draftguitools.gui_snapper.Snapper.grid, ArchCutPlane._CutPlaneTaskPanel.grid, ArchAxis._AxisTaskPanel.grid, ArchPrecast._PrecastTaskPanel.grid, ArchRoof._RoofTaskPanel.grid, ArchAxis.AxisSystemTaskPanel.grid, ArchWindow._ArchWindowTaskPanel.grid, ArchPrecast._DentsTaskPanel.grid, ArchSectionPlane.SectionPlaneTaskPanel.grid, ArchComponent.ComponentTaskPanel.grid, DraftGui.FacebinderTaskPanel.grid, Base::LogLevel.isEnabled(), draftguitools.gui_snapper.Snapper.isEnabled(), draftguitools.gui_snapper.Snapper.mk, draftguitools.gui_snapper.Snapper.radius, DraftGui.DraftToolBar.radius, draftguitools.gui_snapper.Snapper.selectMode, draftguitools.gui_snapper.Snapper.setCursor(), draftguitools.gui_snapper.Snapper.tracker, ArchPanel.CommandPanel.tracker, ArchWindow._CommandWindow.tracker, ArchStructure._CommandStructure.tracker, ArchWall._CommandWall.tracker, and draftguitools.gui_arcs.Arc_3Points.tracker.

◆ snapToHold()

def draftguitools.gui_snapper.Snapper.snapToHold (   self,
  point 
)

◆ snapToIntersection()

◆ snapToMidpoint()

def draftguitools.gui_snapper.Snapper.snapToMidpoint (   self,
  shape 
)

◆ snapToObject()

def draftguitools.gui_snapper.Snapper.snapToObject (   self,
  lastpoint,
  active,
  constrain,
  eline,
  point,
  oldActive 
)
Snap to an object.

References draftguitools.gui_snapper.Snapper.cstr(), Base::LogLevel.isEnabled(), draftguitools.gui_snapper.Snapper.isEnabled(), draftguitools.gui_snapper.Snapper.lastObj, draftguitools.gui_snapper.Snapper.lastSnappedObject, draftguitools.gui_snapper.Snapper.maxEdges, draftguitools.gui_snapper.Snapper.mk, draftguitools.gui_snapper.Snapper.radius, DraftGui.DraftToolBar.radius, draftguitools.gui_line_add_delete.AddPoint.running, ArchNesting.Nester.running, draftguitools.gui_offset.Offset.running, draftguitools.gui_line_add_delete.DelPoint.running, draftguitools.gui_snapper.Snapper.running, App::PropertyExpressionEngine.running, draftguitools.gui_edit.Edit.running, Gui::GUISingleApplication::Private.running, Gui::PythonDebuggerP.running, draftguitools.gui_snapper.Snapper.selectMode, draftguitools.gui_snapper.Snapper.setArchDims(), draftguitools.gui_snapper.Snapper.setCursor(), draftguitools.gui_snapper.Snapper.snapInfo, draftguitools.gui_snapper.Snapper.snapToAngles(), draftguitools.gui_snapper.Snapper.snapToCenter(), draftguitools.gui_snapper.Snapper.snapToDim(), draftguitools.gui_snapper.Snapper.snapToElines(), draftguitools.gui_snapper.Snapper.snapToEndpoints(), draftguitools.gui_snapper.Snapper.snapToFace(), draftguitools.gui_snapper.Snapper.snapToIntersection(), draftguitools.gui_snapper.Snapper.snapToMidpoint(), draftguitools.gui_snapper.Snapper.snapToPerpendicular(), draftguitools.gui_snapper.Snapper.snapToPolygon(), draftguitools.gui_snapper.Snapper.snapToSpecials(), draftguitools.gui_snapper.Snapper.snapToVertex(), draftguitools.gui_snapper.Snapper.spoint, draftguitools.gui_snapper.Snapper.toWP(), draftguitools.gui_snapper.Snapper.tracker, ArchPanel.CommandPanel.tracker, ArchWindow._CommandWindow.tracker, ArchStructure._CommandStructure.tracker, ArchWall._CommandWall.tracker, draftguitools.gui_arcs.Arc_3Points.tracker, and draftguitools.gui_snapper.Snapper.trackLine.

◆ snapToOrtho()

def draftguitools.gui_snapper.Snapper.snapToOrtho (   self,
  shape,
  last,
  constrain 
)

◆ snapToPerpendicular()

def draftguitools.gui_snapper.Snapper.snapToPerpendicular (   self,
  shape,
  last 
)

◆ snapToPolar()

◆ snapToPolygon()

def draftguitools.gui_snapper.Snapper.snapToPolygon (   self,
  obj 
)

◆ snapToSpecials()

◆ snapToVertex()

def draftguitools.gui_snapper.Snapper.snapToVertex (   self,
  info,
  active = False 
)

◆ toggle_snap()

def draftguitools.gui_snapper.Snapper.toggle_snap (   self,
  snap,
  set_to = None 
)
Sets the given snap on/off according to the given parameter

References draftguitools.gui_snapper.Snapper.active_snaps, and draftguitools.gui_snapper.Snapper.save_snap_state().

◆ toggleGrid()

def draftguitools.gui_snapper.Snapper.toggleGrid (   self)
Toggle FreeCAD Draft Grid.

◆ toWP()

◆ unconstrain()

Member Data Documentation

◆ active

draftguitools.gui_snapper.Snapper.active

◆ active_snaps

◆ activeview

draftguitools.gui_snapper.Snapper.activeview

◆ affinity

draftguitools.gui_snapper.Snapper.affinity

◆ basepoint

draftguitools.gui_snapper.Snapper.basepoint

◆ callbackClick

draftguitools.gui_snapper.Snapper.callbackClick

◆ callbackMove

draftguitools.gui_snapper.Snapper.callbackMove

◆ constrainLine

draftguitools.gui_snapper.Snapper.constrainLine

◆ constraintAxis

◆ cursorMode

draftguitools.gui_snapper.Snapper.cursorMode

◆ cursors

draftguitools.gui_snapper.Snapper.cursors

◆ dim1

◆ dim2

◆ extLine

◆ extLine2

◆ forceGridOff

draftguitools.gui_snapper.Snapper.forceGridOff

◆ grid

◆ holdPoints

◆ holdTracker

◆ lastExtensions

◆ lastObj

◆ lastSnappedObject

draftguitools.gui_snapper.Snapper.lastSnappedObject

◆ mask

◆ maxEdges

◆ mk

◆ polarAngles

draftguitools.gui_snapper.Snapper.polarAngles

◆ pt

◆ radius

◆ radiusTracker

◆ running

◆ selectMode

◆ snapInfo

draftguitools.gui_snapper.Snapper.snapInfo

◆ snapObjectIndex

draftguitools.gui_snapper.Snapper.snapObjectIndex

◆ snaps

draftguitools.gui_snapper.Snapper.snaps

◆ snapStyle

◆ spoint

draftguitools.gui_snapper.Snapper.spoint

◆ toolbar

◆ tracker

◆ trackers

draftguitools.gui_snapper.Snapper.trackers

◆ trackLine

◆ ui

draftguitools.gui_snapper.Snapper.ui

◆ view


The documentation for this class was generated from the following file:
  • src/Mod/Draft/draftguitools/gui_snapper.py