Laxkit  0.0.7.1
Public Member Functions | Public Attributes | Protected Attributes
LaxInterfaces::MeasureInterface Class Reference

Measure length, angle and area in various ways. More...

Inheritance diagram for LaxInterfaces::MeasureInterface:
Inheritance graph
[legend]

List of all members.

Public Member Functions

 MeasureInterface (int nid, Laxkit::Displayer *ndp)
virtual ~MeasureInterface ()
 Empty destructor.
virtual anInterfaceduplicate (anInterface *dup)
 Return dup of this. Copies over creationstyle, creatp/v, createlen, col1, col2.
virtual int scan (int x, int y)
 Scan for point.
virtual int LBDown (int x, int y, unsigned int state, int count)
 Creates new data if not click down on one...
virtual int LBUp (int x, int y, unsigned int state)
 If data, then call viewport->ObjectMoved(data).
virtual int MouseMove (int x, int y, unsigned int state)
virtual int CharInput (unsigned int ch, const char *buffer, int len, unsigned int state)
virtual int Refresh ()
virtual void deletedata ()
 Delete points.
virtual int InterfaceOn ()
 Sets showdecs=1, and needtodraw=1.
virtual int InterfaceOff ()
 Calls Clear(), sets showdecs=0, and needtodraw=1.
virtual const charwhattype ()
virtual const charwhatdatatype ()
- Public Member Functions inherited from LaxInterfaces::anInterface
 anInterface ()
 This constructor assigns id=getUniqueNumber().
 anInterface (int nid)
 Constructor to assign just the id, set other stuff to 0.
 anInterface (int nid, Laxkit::Displayer *ndp)
 anInterface (anInterface *nowner, int nid)
 Constructor to assign owner and id.
 anInterface (anInterface *nowner, int nid, Laxkit::Displayer *ndp)
virtual Laxkit::ShortcutHandlerGetShortcuts ()
 Return a ShortcutHandler that contains stacks of bound shortcuts and possible actions.
virtual int PerformAction (int actionnumber)
virtual const charIconId ()
virtual const charName ()
virtual int draws (const char *atype)
 Returns !strcmp(whatdatatype(),atype).
virtual void Clear ()
 Default just calls Clear(NULL).
virtual int RemoveChild ()
 If there is a child, do something to remove it.
virtual int AddChild (LaxInterfaces::anInterface *ch, int absorbcount, int addbefore)
virtual int Needtodraw ()
 Must return nonzero if the data needs to be drawn, that is to say Refresh must be called.
virtual int Needtodraw (int n)
virtual int LBDown (int x, int y, unsigned int state, int count, const Laxkit::LaxMouse *d)
virtual int MBDown (int x, int y, unsigned int state, int count, const Laxkit::LaxMouse *d)
virtual int RBDown (int x, int y, unsigned int state, int count, const Laxkit::LaxMouse *d)
virtual int LBUp (int x, int y, unsigned int state, const Laxkit::LaxMouse *d)
virtual int MBUp (int x, int y, unsigned int state, const Laxkit::LaxMouse *d)
virtual int RBUp (int x, int y, unsigned int state, const Laxkit::LaxMouse *d)
virtual int WheelUp (int x, int y, unsigned int state, int count, const Laxkit::LaxMouse *d)
virtual int WheelDown (int x, int y, unsigned int state, int count, const Laxkit::LaxMouse *d)
virtual int MouseMove (int x, int y, unsigned int state, const Laxkit::LaxMouse *d)
virtual int CharInput (unsigned int ch, const char *buffer, int len, unsigned int state, const Laxkit::LaxKeyboard *d)
virtual int KeyUp (unsigned int ch, unsigned int state, const Laxkit::LaxKeyboard *d)
virtual int DeviceChange (const Laxkit::DeviceEventData *e)
virtual int Event (const Laxkit::EventData *e, const char *mes)
 Respond to events, particularly menu events from a menu created from ContextMenu().
virtual void ExposeChange (Laxkit::ScreenEventData *e)
virtual void ViewportResized ()
 Called after the parent viewport gets resized.
virtual void Mapped ()
 Called after the parent viewport gets mapped (made visible).
virtual void Unmapped ()
 Called after the parent viewport gets mapped (made invisible, such as offscreen, not merely obscured).
virtual void PostMessage (const char *message)
 If viewport, use that, else app->postmessage().
virtual Laxkit::MenuInfoContextMenu (int x, int y, int deviceid)
 Return a context sensitive menu for screen position (x,y).
virtual int UseThis (int id, int ndata)
 Return 1 if the id/ndata is used, otherwise zero.
virtual int UseThis (Laxkit::anObject *ndata, unsigned int mask=0)
 Return 1 if interface can use that data, otherwise, the calling code must appropriately dispose of ndata.
virtual int UseThisObject (ObjectContext *oc)
virtual int DrawData (Laxkit::anObject *ndata, Laxkit::anObject *a1=NULL, Laxkit::anObject *a2=NULL, int info=0)
 Redefine this for interfaces that can draw data not owned, without loosing current data.
virtual Laxkit::anXWindowCurrentWindow (Laxkit::anXWindow *ncur)
 Set the window the interface works on to ncur. Returns ncur. If ncur==NULL, then just return current viewport.
virtual void Clear (SomeData *d)=0
 Clear the data from the interface only if d is the interface's current data.
virtual ObjectContextContext ()
virtual void Dp (Laxkit::Displayer *ndp)
 Set the dp to ndp, and update curwindow/viewport.
virtual int DrawDataDp (Laxkit::Displayer *tdp, SomeData *tdata, Laxkit::anObject *a1=NULL, Laxkit::anObject *a2=NULL, int info=1)
 Use a different dp to draw data with.
virtual flatpoint realtoscreen (flatpoint r)
 Do a little extra checking to find what point r should correspond to.
virtual flatpoint screentoreal (int x, int y)
 Do a little extra checking to find what point (x,y) should correspond to.
virtual double Getmag (int c=0)
 Do a little extra checking to find what the magnification is.
virtual double GetVMag (int x, int y)
 Do a little extra checking to find what the magnification is.
virtual void dump_out (FILE *f, int indent, int what, Laxkit::anObject *savecontext)
 Default settings saving is to output nothing.
virtual void dump_in_atts (LaxFiles::Attribute *att, int flag, Laxkit::anObject *loadcontext)
 Placeholder for dumping in settings.
- Public Member Functions inherited from LaxFiles::DumpUtility
virtual Attributedump_out_atts (Attribute *att, int what, Laxkit::anObject *savecontext)
 Default is return NULL. what==0 means write out normal Attribute formatted things.
virtual void dump_in (FILE *f, int indent, int what, Laxkit::anObject *loadcontext, Attribute **att)
 Read in a file segment as an Attribute, and pass parsing duties to dump_in_atts.
virtual ~DumpUtility ()
 Empty virtual destructor.

Public Attributes

unsigned long controlcolor
int target
int mode
int showdecs
- Public Attributes inherited from LaxInterfaces::anInterface
charname
 An instance name.. ***don't think this is used anywhere at the moment.
int id
 Must be positive, other values are reserved for internal use.
unsigned long style
 Style flags for the interface. Meaning depends on the interface.
int interface_type
 What sort of interface this is. Default is INTERFACE_Tool.
Laxkit::anXAppapp
 The application this interface works with.
Laxkit::anXWindowcurwindow
 The window the interface currently works on.
anInterfaceowner
 The interface that owns this one.
anInterfacechild
 The child of this interface. See anInterface::owner. This is dec_counted in destructor.
int primary
 Whether this is supposed to be a 'main' interface, or merely a helper.
int needtodraw
 Whether the interface thinks it has to refresh.

Protected Attributes

int mx
int my
int draggingmode
Coordinatecurpoint
Coordinatepoints
double extra [6]
LineStyle linestyle
- Protected Attributes inherited from LaxInterfaces::anInterface
Laxkit::ButtonDownInfo buttondown
ViewportWindowviewport
 curwindow dynamically cast to ViewportWindow. Thus, it will be NULL if it is not a ViewportWindow.
Laxkit::Displayerdp
 The Displayer used by the controlling window.

Detailed Description

Measure length, angle and area in various ways.

Adjustable units: correspond to screen (inches or pixels), viewport, viewport+other transform, or any of those plus a correction factor, so you can have actual units be inches, for instance, but measure distances using 1 lightyear == .5 inches.

Left-click and drag with no current produces a line. Shows on screen the measurment. With current line, hover over endpoint, click drag to produce an attached line, measures both lines and angles. With more than one line, dragging a line to the initial point will close the line, producing an area measurement.

Modes:

  1. Measure line segments by default
  2. Measure angles not distances, assumes at least 2 line segments.
  3. Measure area, assumes free form line dragged out, close path automatically

Constructor & Destructor Documentation

LaxInterfaces::MeasureInterface::MeasureInterface ( int  nid,
Laxkit::Displayer ndp 
)

Member Function Documentation

int LaxInterfaces::MeasureInterface::LBDown ( int  x,
int  y,
unsigned int  state,
int  count 
)
virtual

Creates new data if not click down on one...

Shift-click makes a new color spot.

Todo:
*** shift-click near an already selected but perhaps obscured point should not select the point that is obscuring it instead

References LaxInterfaces::Coordinate::connect(), deletedata(), and scan().


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

Mon Feb 17 2014 11:52:58, Laxkit