|
Laxkit
0.0.7.1
|
Measure length, angle and area in various ways. More...

Public Member Functions | |
| MeasureInterface (int nid, Laxkit::Displayer *ndp) | |
| virtual | ~MeasureInterface () |
| Empty destructor. | |
| virtual anInterface * | duplicate (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 char * | whattype () |
| virtual const char * | whatdatatype () |
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::ShortcutHandler * | GetShortcuts () |
| Return a ShortcutHandler that contains stacks of bound shortcuts and possible actions. | |
| virtual int | PerformAction (int actionnumber) |
| virtual const char * | IconId () |
| virtual const char * | Name () |
| 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::MenuInfo * | ContextMenu (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::anXWindow * | CurrentWindow (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 ObjectContext * | Context () |
| 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 Attribute * | dump_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 | |
| char * | name |
| 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::anXApp * | app |
| The application this interface works with. | |
| Laxkit::anXWindow * | curwindow |
| The window the interface currently works on. | |
| anInterface * | owner |
| The interface that owns this one. | |
| anInterface * | child |
| 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 |
| Coordinate * | curpoint |
| Coordinate * | points |
| double | extra [6] |
| LineStyle | linestyle |
Protected Attributes inherited from LaxInterfaces::anInterface | |
| Laxkit::ButtonDownInfo | buttondown |
| ViewportWindow * | viewport |
| curwindow dynamically cast to ViewportWindow. Thus, it will be NULL if it is not a ViewportWindow. | |
| Laxkit::Displayer * | dp |
| The Displayer used by the controlling window. | |
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:
| LaxInterfaces::MeasureInterface::MeasureInterface | ( | int | nid, |
| Laxkit::Displayer * | ndp | ||
| ) |
Sets target to viewport.
References LaxInterfaces::anInterface::app, LaxInterfaces::anInterface::needtodraw, and LaxInterfaces::anInterface::style.
Referenced by duplicate().
Creates new data if not click down on one...
Shift-click makes a new color spot.
References LaxInterfaces::Coordinate::connect(), deletedata(), and scan().