 
                 Patent Grant
 Patent Grant
                     8044953
 8044953
                    1. Field of the Invention
The present invention is directed to an improved system of push tumble navigation.
2. Description of the Related Art
Surface following can be used to view an object of a scene while inspecting the surface or performing other operations, such as a painting. When users are distant from the object and move toward it, a visual discontinuity can occur when the freeform motion is converted into surface following. When following a surface the closest point on the surface needs to be found so that a constant distance can be maintained. Simple ray casting to locate a closest point can be time consuming. When following a surface the user can also experience a view that is disorienting when some objects are traversed. Users performing surface following can use various types of motion specification. As a surface is being followed variations in the surface including cavities and obstacles can be encountered.
What is needed is a system that can accommodate the above discussed needs.
It is an aspect of the present invention to provide a transition from freeform navigation to surface following and view navigation.
It is also an aspect of the present invention to reduce the processing time for finding a closest surface point during navigation.
It is another aspect of the present invention to allow the selection of different camera view models that designate the up direction during navigation.
It is a further aspect of the present invention to provide for a pull model for motion and use a local up model for internal calculations.
It is an additional aspect of the present invention to limit view changes for concave surfaces.
It is an aspect of the present invention to look ahead to anticipate obstacles in the navigation path.
The above aspects can be attained by a system that transitions from freeform camera motion to surface following motion as a surface of an object is approached. When the surface is reached and while following the surface the user can designate an up model that will conform the view to a users expectations while the system operates using a particular up direction for computations. A restricted surface field of view along with an obstacle field of view can be used by the system to prevent the camera from behaving unexpectedly at cavities and when encountering obstacles.
These together with other aspects and advantages which will be subsequently apparent, reside in the details of construction and operation as more fully hereinafter described and claimed, reference being had to the accompanying drawings forming a part hereof, wherein like numerals refer to like parts throughout.
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
The present invention is a system that generates or receives a two-dimensional input, automatically pans a view of a model according to the two-dimensional input, automatically zooms the view according to the two-dimensional input, and automatically tumbles or rotates the view according to the two-dimensional input, where the panning, zooming, and tumbling are relative to a fixed point in the space of the model. The behavior of the invention could be considered to be like a camera that hovers above a surface or a HoverCam. A cylinder is a type of object or model that can be viewed with a viewing system. 
The navigation discussed above could be used together with traditional freeform navigation tools with the user switching between them as needed. However, it is preferable to interoperate between the various camera techniques in a fairly seamless way. Freeform camera motion allows the user to navigate to any point in space and to face in any direction. For specific surface-based tasks like 3D painting or sculpting, the present invention provides a subset of this freedom with the benefit of following the surface. Switching from surface following, as depicted in 
The layers of influence 142 and 144 around each object can be automatically generated by, for example, by using a spherical distance from a center of the object to set limit 142 and using the mouse-wheel is used to zoom in or out to specify a new fixed distance 144 for the surface following algorithm. The outer layer 142 is typically quite far from the object 140 surface and specifies a field of influence. Once a freeform camera enters this field, the surface following camera is weighted together with the freeform camera so that the camera view will be pulled towards the outer limit 146 of the orbit distance of the object 162 (see 
In 
  
When in the surface following mode (inside surface 146) the present invention determines the view direction by determining the closest point on the surface of the model. A 3D model is typically represented as a polygonal mesh. Iterating through every polygon in the model for closest point can determine the closest point in a polygonal mesh. However, such an analysis can be time consuming and may not be suitable for a real-time interactive operation, as is preferred. To reduce the time to find the closest point, preferably, an indexing structure, conventionally called a sphere-tree, is generated when the user loads an object. The sphere-tree is a hierarchal structure that encloses the polygons within the model (see 
To compute an approximate closest point on the surface of the mesh, the system performs (see 
It is often the case that some of the polygons lie on the boundary of the restricted FOV. For these polygons, if the true closest point is outside the FOV, then the closest point of interest will lie along the intersection of our FOV with the polygon. When this happens, the system performs a ray-casting technique about the perimeter of the FOV, finding the closest intersection of a ray with the polygon. If the search method ignored these cases, the system could mistakenly only select closest points on polygons completely within the FOV.
As depicted in 
In performing a surface following procedure, an up vector is typically implied relative to a view throughout the procedure. However, this can have unexpected consequences, such as when a globe is being navigated and the view traversed the top of the sphere and the sphere, such as a globe of the world, is viewed upside down. When closely inspecting an object, especially in a visually abstract empty virtual environment, the problem of correctly orienting the camera, so objects do not appear to be sideways or upside-down, is a problem. Furthermore, the model chosen to derive the up-vector at a given camera position, or given a certain camera motion, may alter the overall camera metaphor. To solve this problem the present invention defines four up-models: global, local, driving, and custom.
For a global up-vector model, consider a globe 262 (see 
In the egocentric local model, the up-vector 300 is view dependent and always points toward the top of the viewport (see 
In the driving model, for some objects, the user may wish to have the feeling that moving the input device left or right should turn the object so that moving (the device) up is always “forward”. Again, using the globe 342 as an example (see 
Some objects may require custom up-vector fields. For example, a model of an automobile 382 (see 
The processing associated with the use of the up models discussed above starts (see 
In the custom model, the system, as depicted in 
The mapping of mouse motion to camera motion may either be push (egocentric) or pull (exocentric). In a push mapping, the user conceptually pushes the camera so that, for example, moving the mouse from left to right would push the camera to the right causing the model to appear to move left. With a pull mapping, the user pulls the world in the direction of motion so that dragging from left to right moves the object from left to right, achieved by moving the camera to the left.
The invention is like the user is controlling a craft floating above the surface of an object and so one may expect the push mapping to be most effective. However, given the object inspection metaphor, the user is typically expected to be very close to the object so that it fills most of the display. As such, when the user clicks to drag the mouse, the cursor will typically be over the object when the mouse button is clicked. This strongly conveys a metaphor of grabbing the object at that position and dragging it in the mouse direction, which implies that the camera will move in the opposite direction. For this reason, the pull mapping is preferred.
During the typical surface following processing as discussed in the related application, the system sets 442 the direction of the moved view to the direction of the selected closest ray and then moves 444 the view point along the newly set direction such that it is again the specified distance from the model. To allow for the different types of mapping discussed above, between the these operations, as depicted in 
Still, during a single click-drag-release input event series, a discrepancy can occur between the direction that the input device is moving and the intended camera motion in the scene. For example, for the camera motion shown in 
An appropriate choice for the up-vector model by the user may be highly content dependent and may be a user preference or may be uniquely associated with each model in a scene.
This basic algorithm discussed in the related application handles simple convex surfaces, slightly concave surfaces, and jumps across gaps or holes. However, the true closest point may be outside the current field of view (FOV) or may even be behind the camera. In these cases, turning the camera to immediately face the new closest point would be quite disorienting and may result in some undesirable effects. This can occur if the object has protrusions, or cavities. When gliding over a cavity, for example, the closest point can jump from one edge of the cavity to the other. To solve this problem, after the camera is turned toward the surface and the distance to the object is adjusted as discussed in the related application referenced above, the present invention clips the final distance traveled (of both the eye and the look-at point) to minimize these effects, slowly turning the camera to the intended position.
Specifically, to maintain smooth camera motion, the clipping looks at the vectors (see 
This motion-clipping step handles sharp camera turns and jumps across holes in an object or jumps across gaps to other objects. 
However, the camera motion shown in 
This constraint helps the present invention to handle a number of situations. In the torus example, a new closest point is found directly across the hole and the motion clipping turns the camera toward it. In concave shapes 482 (see 
The restricted FOV for searching taken together with the motion clipping, handle the cases where there are multiple solutions for a closest point thereby providing the expected camera motion.
While the basic camera update operations discussed above and in the related application generate smooth camera motion paths, tight corners can create hooks in the path that could be avoided. The problem is caused by the restricted search FOV that prevents the algorithm from finding an upcoming corner. For example, when moving right along a wall 492 towards a corner 494, the system looks directly ahead at the wall 492 while panning right. However, the restricted FOV prevents seeing the approaching corner. The corner will eventually be found but this will push the camera back to the fixed distance from the surface effectively generating a hook in the camera path 496 as shown in 
To achieve the preferred trajectory, the present invention includes a second FOV 502 that searches for obstacles in the direction of motion as depicted in 
With the motion direction FOV 502, when a corner 512 is reached, the camera correctly turns in the direction of the input until it continues along the next wall 514 as shown in 
  
A single object FOV and a single obstacle FOV have been discussed for controlling the camera path. However, additional obstacle FOVs may be used, such as an FOV that would detect a protrusion coming from behind the camera. Other constraints may be added such as a “distance from floor” constraint used for an architectural walk-through. In the discussion above, the view of the scene by the camera is of the object when the camera is performing surface following. However, the view by the camera need not be of the object or surface that is being followed. For example, in architectural walk-through of a virtual room 542 (see 
The present invention is included in a system 580, such as depicted in 
The system also includes permanent or removable storage, such as magnetic and optical discs, RAM, ROM, etc. on which the process and data structures of the present invention can be stored and distributed. The processes can also be distributed via, for example, downloading over a network such as the Internet.
The present invention has been described with respect to computationally finding a closest point. It is possible to use other methods such as a hardware-generated z-buffer, may be used to find the closest point. A smoothing pass can also be performed on the eye and look-at points to further smooth the resulting camera motion. The system can include other types of interactions, for example, the user may be allowed to transiently engage a “look-around” mode, switching back to HoverCam after a drag operation.
Additional information related to the present invention can be found in Khan, Azam et al., “Interaction: HoverCam: interactive 3D navigation for proximal object inspection”, Proceedings of the 2005 symposium on Interactive 3D graphics and games, April 2005 incorporated by reference herein.
A compact disc is included herewith and incorporated by reference herein having thereon a video that shows features of the present invention and can be played using Windows Media Player TM.
The many features and advantages of the invention are apparent from the detailed specification and, thus, it is intended by the appended claims to cover all such features and advantages of the invention that fall within the true spirit and scope of the invention. Further, since numerous modifications and changes will readily occur to those skilled in the art, it is not desired to limit the invention to the exact construction and operation illustrated and described, and accordingly all suitable modifications and equivalents may be resorted to, falling within the scope of the invention.
This application is related to and is a continuation-in-part of and claims priority to U.S. application entitled PUSH-TUMBLE THREE DIMENSIONAL NAVIGATION SYSTEM having Ser. No. 10/183,432, by Khan, filed Jun. 28, 2002 now U.S. Pat. No. 7,042,449 and incorporated by reference herein.
| Number | Name | Date | Kind | 
|---|---|---|---|
| 5276785 | Mackinlay et al. | Jan 1994 | A | 
| 5943056 | Sato et al. | Aug 1999 | A | 
| 6064389 | Berry et al. | May 2000 | A | 
| 6097393 | Prouty et al. | Aug 2000 | A | 
| 6144375 | Jain et al. | Nov 2000 | A | 
| 6222557 | Pulley et al. | Apr 2001 | B1 | 
| 6377256 | Light et al. | Apr 2002 | B1 | 
| 6640185 | Yokota et al. | Oct 2003 | B2 | 
| 7038712 | Livingston et al. | May 2006 | B1 | 
| 7058239 | Singh et al. | Jun 2006 | B2 | 
| 7123777 | Rondinelli et al. | Oct 2006 | B2 | 
| 7589732 | Burtnyk et al. | Sep 2009 | B2 | 
| 20020050988 | Petrov et al. | May 2002 | A1 | 
| 20020075258 | Park et al. | Jun 2002 | A1 | 
| 20040189802 | Flannery | Sep 2004 | A1 | 
| 20040210852 | Balakrishnan et al. | Oct 2004 | A1 | 
| 20060080604 | Anderson | Apr 2006 | A1 | 
| Number | Date | Country | |
|---|---|---|---|
| 20060227134 A1 | Oct 2006 | US | 
| Number | Date | Country | |
|---|---|---|---|
| Parent | 10183432 | Jun 2002 | US | 
| Child | 11390306 | US |