| 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Object
  |
  +--sub_arctic.input.dispatch_agent
        |
        +--sub_arctic.input.focus_dispatch_agent
              |
              +--sub_arctic.input.single_focus_agent
                    |
                    +--sub_arctic.input.snap_drag_agent
Focus agent that implements snap-dragging. Snap dragging is an interaction technique where objects being dragged snap to interesting points within objects they are dragged over. These interesting points typically represent semantically interesting places to "let go of" the dragged object such as positions where they will legally "connect to" other object. The determination of what represents an interesting point is done by means of predicates on the objects snapped from (the ones being dragged) and snapped to (the ones "under" them). In snap dragging, dragged objects implement the snap_draggable protocol, while objects which they are dragged over, and can be snapped to, implement the snap_targetable protocol (and generally are called snap targets).
Each dragged object advertises a set of feature points. By default base_interactor provides 5: the 4 corners plus the center of the object. Other object types may provide additional or complete different points that suit their semantics. Each active feature point is eligible to snap to a snap target object. Snap target objects are not limited to being points and may implement areas, lines, points, and other geometric forms. With each target comes a geometric test to determine if a point is considered close enough to the target to snap to it (and provide a distance to it). Snapping occurs by considering active feature point within snapping distance of a target. For each geometrically possible snap, semantic tests are performed to determine if the snap is semantically acceptable (i.e., it constitutes an "interesting" snap). The closest candidate snap that passes semantic tests is performed. Both dragged and target objects are informed of the snap (an any subsequent unsnap) and given the opportunity to provide feedback. If snaps are geometrically possible, but none pass the semantic tests, then starting with the closest each is given the opportunity to make a special "anti-snap". This is done to provide negative feedback (I kind of error message) which indicates why a geometrically legal snap has been ruled out semantically.
Once a snap has been performed, users can reject the snap by moving the dragged object out of range of the snap. In addition, the snap can be rejected and disabled (for the duration of the drag operation) by pressing a designated keyboard key (by default space -- this can be changed with the set_snap_break_key() method) while the snap is in force.
Note: in order for snap disabling to occur, this agent needs to be (and by default is) installed before the text focus agent within the agent list of the focus policy.
snap_draggable, 
snap_targetable| Field Summary | |
| protected static int | _bound_traversalTraversal identifier for the snap bound test traversal | 
| protected static int | _snap_break_keyThe keyboard event code used to signal that the currently active snap should be be broken and disabled. | 
| protected  sub_arctic.input.snap_record | active_anti_snapSnap record containing information about the currently active anti-snap (or null if there is none). | 
| protected  java.lang.Object | active_anti_snap_infoApplication specific information about the currently active anti-snap | 
| protected  sub_arctic.input.snap_record | active_snapSnap record containing information about the currently active snap (or null if there is none). | 
| protected  java.lang.reflect.Method | anti_snap_feedbackKeep a reference to the method anti_snap_feedback in our protocol. | 
| protected  java.lang.reflect.Method | anti_snap_toKeep a reference to the method anti_snap_to in our protocol. | 
| protected  java.lang.reflect.Method | drag_endKeep a reference to the method drag_end in the normal move protocol. | 
| protected  java.lang.reflect.Method | drag_feedbackKeep a reference to the method drag_feedback in the normal move protocol. | 
| protected  java.lang.reflect.Method | drag_startKeep a reference to the method drag_start in the normal move protocol. | 
| protected  java.util.Vector | feature_pointsSet of active feature points of the object being dragged (stored as a Vector of Point objects). | 
| protected  int | feature_rect_hHeight of feature point bounding rectangle | 
| protected  int | feature_rect_wWidth of feature point bounding rectangle | 
| protected  int | grab_xGrab x position (start position in local coordinates). | 
| protected  int | grab_yGrab y position (start position in local coordinates). | 
| protected static interactor_pred | is_snap_objInteractor predicate object to test if an object is a snap_targetable. | 
| protected  int | min_feature_xMin x of feature points | 
| protected  int | min_feature_yMin y of feature points | 
| protected  int | num_feature_pointsNumber of active feature points for the object currently being dragged. | 
| protected static interactor_pred | overlapsInteractor predicate object to test if an expanded snap region overlaps the bounds of an object. | 
| protected static traversal_xform | rect_to_childTraversal transformation object to transform a Rectangle from parent to child coordinates. | 
| protected  java.util.Hashtable | rejected_snapsTable of snaps that the user has rejected and disabled for this drag. | 
| protected static interactor_pred | snap_and_overlapInteractor predicate object to test if an object is both a snap_targetable object and passes the overlap test. | 
| protected  java.lang.reflect.Method | snap_feedbackKeep a reference to the method snap_feedback in our protocol. | 
| protected  java.lang.reflect.Method | snap_toKeep a reference to the method snap_to in our protocol. | 
| protected  int | start_xStart x position of the current drag (in global coordinates) | 
| protected  int | start_yStart y position of the current drag (in global coordinates) | 
| protected  java.lang.reflect.Method | unanti_snap_toKeep a reference to the method unanti_snap_to in our protocol. | 
| protected  java.lang.reflect.Method | unsnap_toKeep a reference to the method unsnap_to in our protocol. | 
| Fields inherited from class sub_arctic.input.focus_dispatch_agent | 
| _focus_set,  
_user_info_set | 
| Constructor Summary | |
| snap_drag_agent()Default constructor | |
| Method Summary | |
|  boolean | allowable_focus(focusable candidate_obj)Method to limit the objects allowable as members of the focus set. | 
| static int | bound_traversal()Traversal identifier for the snap bound test traversal | 
| protected  void | break_active_anti_snap(event evt,
                       java.lang.Object user_info)Break the currently active anti_snap | 
| protected  void | break_active_snap(event evt,
                  java.lang.Object user_info)Break the currently active snap. | 
| protected  void | collect_feature_info(interactor obj)Collect feature point information from a new focus object. | 
|  boolean | dispatch_event(event evt,
               java.lang.Object user_info,
               interactor to_obj,
               int seq_num)Dispatch an event under this protocol. | 
|  boolean | event_is_useful(event evt)Method to determine if this agent needs to see a given event. | 
| protected  pick_collector | find_overlapped_targets(int new_x,
                        int new_y,
                        snap_draggable drag_obj)Collect the set of snap target objects whose bounds are within snapping distance of the bounding box of the feature points of the object being dragged. | 
|  boolean | have_active_anti_snap()Indicate whether we have an active anti-snap | 
|  boolean | have_active_snap()Indicate whether we have an active snap | 
|  boolean | have_active()Indicate whether we have either an active snap or anti_snap | 
| protected  void | inform_focus_enter(focusable obj,
                   event evt,
                   java.lang.Object user_info)Override the normal inform_focus_enter to deliver the drag_start(). | 
| protected  void | inform_focus_exit(focusable obj,
                  event evt,
                  java.lang.Object user_info)Override the normal inform_focus_exit to deliver the drag_end(). | 
| protected  boolean | make_anti_snap_active(sub_arctic.input.snap_record snap_rec,
                      event evt,
                      java.lang.Object anti_snap_info,
                      java.lang.Object user_info)Activate a new anti-snap. | 
| protected  boolean | make_snap_active(sub_arctic.input.snap_record snap_rec,
                 event evt,
                 java.lang.Object user_info)Activate a new snap. | 
| protected  boolean | process_snap(int new_x,
             int new_y,
             snap_draggable drag_obj,
             event evt,
             java.lang.Object user_info)Attempt to find a snap point between some active feature point of the currently dragged object and some snap_targetable object. | 
| static void | set_snap_break_key(int char_val)Set the keyboard event code used to signal that the currently active snap should be be broken and disabled. | 
| static int | snap_break_key()The keyboard event code used to signal that the currently active snap should be be broken and disabled. | 
| static int | snap_dist()Distance at which snap points should become active | 
| static int | snap_dist2()Square of distance at which snap points should become active | 
| Methods inherited from class sub_arctic.input.single_focus_agent | 
| add_to_focus, 
clear_focus, 
remove_from_focus, 
set_focus_to | 
| Methods inherited from class sub_arctic.input.focus_dispatch_agent | 
| focus_item, 
focus_set_size, 
is_in_focus, 
user_info_item | 
| Methods inherited from class sub_arctic.input.dispatch_agent | 
| after_dispatch_notify, 
dispatch_unused_event | 
| Methods inherited from class java.lang.Object | 
| clone, 
equals, 
finalize, 
getClass, 
hashCode, 
notify, 
notifyAll, 
toString, 
wait, 
wait, 
wait | 
| Field Detail | 
protected java.lang.reflect.Method snap_to
protected java.lang.reflect.Method snap_feedback
protected java.lang.reflect.Method unsnap_to
protected java.lang.reflect.Method anti_snap_to
protected java.lang.reflect.Method anti_snap_feedback
protected java.lang.reflect.Method unanti_snap_to
protected java.lang.reflect.Method drag_start
protected java.lang.reflect.Method drag_feedback
protected java.lang.reflect.Method drag_end
protected static int _snap_break_key
protected int start_x
protected int start_y
protected int grab_x
protected int grab_y
protected java.util.Vector feature_points
protected int num_feature_points
protected int min_feature_x
protected int min_feature_y
protected int feature_rect_w
protected int feature_rect_h
protected static final int _bound_traversal
protected static final interactor_pred overlaps
protected static final interactor_pred is_snap_obj
protected static final interactor_pred snap_and_overlap
protected static final traversal_xform rect_to_child
protected sub_arctic.input.snap_record active_snap
protected sub_arctic.input.snap_record active_anti_snap
protected java.lang.Object active_anti_snap_info
protected java.util.Hashtable rejected_snaps
| Constructor Detail | 
public snap_drag_agent()
| Method Detail | 
public boolean allowable_focus(focusable candidate_obj)
candidate_obj - the object we are deciding uponpublic static int snap_break_key()
public static void set_snap_break_key(int char_val)
public boolean event_is_useful(event evt)
evt - the event in questionprotected void collect_feature_info(interactor obj)
interactor - obj the object we are collecting feature points from.
protected void inform_focus_enter(focusable obj,
                                  event evt,
                                  java.lang.Object user_info)
obj - the object we are draggingevt - the event that "caused" the start of drag (typically 
                  a mouse button down event)user_info - an uninterpreted object to be passed to the object
protected void inform_focus_exit(focusable obj,
                                 event evt,
                                 java.lang.Object user_info)
obj - the object we are draggingevt - the event that "caused" the end of drag (typically
                  a mouse button up event)user_info - an uninterpreted object to be passed to the objectpublic static int snap_dist()
public static int snap_dist2()
public static int bound_traversal()
public boolean have_active_snap()
public boolean have_active_anti_snap()
public boolean have_active()
protected void break_active_snap(event evt,
                                 java.lang.Object user_info)
event - evt       the event "causing" the break.Object - user_info the user info value passed to the object.
protected void break_active_anti_snap(event evt,
                                      java.lang.Object user_info)
event - evt       the event "causing" the break.Object - user_info the user info value passed to the object.
protected boolean make_snap_active(sub_arctic.input.snap_record snap_rec,
                                   event evt,
                                   java.lang.Object user_info)
snap_record - snap_rec  record describing the snap we are activating.event - evt       event that "caused" the snap.Object - user_info the user info passed to the objects.
protected boolean make_anti_snap_active(sub_arctic.input.snap_record snap_rec,
                                        event evt,
                                        java.lang.Object anti_snap_info,
                                        java.lang.Object user_info)
snap_record - snap_rec  record describing the anti-snap we are 
                              activating.event - evt       event that "caused" the anti-snap.Object - user_info the user info passed to the objects.
protected pick_collector find_overlapped_targets(int new_x,
                                                 int new_y,
                                                 snap_draggable drag_obj)
int - new_x    new left edge of the dragged objectint - new_y    new top edge of the dragged objectsnap_draggable - drag_obj the dragged object
protected boolean process_snap(int new_x,
                               int new_y,
                               snap_draggable drag_obj,
                               event evt,
                               java.lang.Object user_info)
int - new_x     new x position of the dragged object.int - new_y     new y position of the dragged object.snap_draggable - drag_obj  the dragged object.event - evt,      the event "causing" the drag.Object - user_info the user info to be passed.
public boolean dispatch_event(event evt,
                              java.lang.Object user_info,
                              interactor to_obj,
                              int seq_num)
evt - the event being dispatched (already approved by 
                  event_is_useful())user_info - an uninterpreted info object to be passed to the 
                  dragged objectto_obj - for focus agents this is always nullseq_num - for focus agents this is ignoredprocess_snap(int, int, sub_arctic.input.snap_draggable, sub_arctic.input.event, java.lang.Object)| 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||