Aspects of the present invention are directed generally to apparatus and methods for controlling a graphical user interface (GUI). More particularly, aspects of the present invention relate to capturing and/or storing electronic ink in an efficient manner.
Typical computer systems, especially computer systems using graphical user interface (GUI) systems such as Microsoft WINDOWS, are optimized for accepting user input from one or more discrete input devices such as a keyboard for entering text, and a pointing device such as a mouse with one or more buttons for driving the user interface. The ubiquitous keyboard and mouse interface provides for fast creation and modification of documents, spreadsheets, database fields, drawings, photos and the like. However, there is a significant gap in the flexibility provided by the keyboard and mouse interface as compared with the non-computer (i.e., standard) pen and paper. With the standard pen and paper, a user edits a document, writes notes in a margin, and draws pictures and other shapes and the like. In some instances, a user may prefer to use a pen to mark-up a document rather than review the document on-screen because of the ability to freely make notes outside of the confines of the keyboard and mouse interface.
Some computer systems permit a user to draw on a screen. For example, the Microsoft READER application permits one to add electronic ink (also referred to herein as “ink”) to a document. The system stores the ink and provides it to a user when requested. Other applications (for example, drawing applications as known in the art are associated with the Palm 3. x and 4. x and PocketPC operating systems) permit the capture and storage of drawings. These drawings include other properties associated with the ink strokes used to make up the drawings. For instance, line width and color may be stored with the ink. One goal of these systems is to replicate the look and feel of physical ink being applied to a piece of paper. However, physical ink on paper may have significant amounts of information not captured by the electronic collection of a coordinates and connecting line segments. Some of this information may include the thickness of the pen tip used (as seen through the width of the physical ink), the shape of the pen tip, the speed at which the ink was deposited, and the like.
Another problem has arisen in the storage of ink. The fact that ink may be created from number of different platforms (for example, from interactions between a stylus and a digitizer, from a mouse and the like) yields a variety of ink sizes (based at least in part on the resolution and sampling frequency of the digitizer or ink input system). To reduce the size of created ink with its variety of data points, one technique includes normalizing the size of the ink from the coordinate system in which it has been captured (referred to herein as the ink's native coordinates) to a different coordinate system. This normalization may have devastating effects on the ability of a handwriting recognition system to recognize and appropriately treat ink. For instance,
However, the device or system that captured the ink of
Application of this process results in the quantization of the ink. Other quantizations or roundings are possible.
The original set of coordinates when divided by 4 is as follows:
A further problem is shown in
The ink from tablet 1304 has kept the same coordinate system yet the ink is so large that it dwarfs the other ink in output 1305, despite the fact that the ink of tablet 1304 was originally created with the same size drawing on the tablet 1304.
Yet another problem with handling ink occurs in compression of the ink after scaling.
Accordingly, an improved system is needed for storing information with its associated properties that minimize the size of the data used to represent the desired information.
The present invention provides a flexible and efficient system, method, and data structure for receiving, storing, and rendering electronic ink.
Aspects of the present invention are directed to an improved system, method and data structure for storing ink in a first coordinate system and a mapping to a second coordinate system. In some embodiments, the ink coordinates and the mapping (also referred to as a transform table) are stored together in an ink object. In further embodiments, the ink coordinates and mapping are stored in an ink object in a serialized format so as to minimize the size of the ink object. In yet other embodiments, the mappings may be combined to minimize degradation or loss of resolution of the ink (caused in some instances by rounding errors). Finally, some embodiments relate to defining and using a virtual ink space as the second coordinate system.
These and other features and aspects of the invention will be apparent upon consideration of the following detailed description of the preferred embodiments.
The foregoing summary of the invention, as well as the following detailed description of preferred embodiments, is better understood when read in conjunction with the accompanying drawings, which are included by way of example, and not by way of limitation with regard to the claimed invention.
The following description is divided into sub-sections to assist the reader. The sub-sections include: characteristics and storage of ink; terms; general-purpose computer and associated hardware; an example of strokes of ink; transforming ink; data structures for storing ink and transform mappings; transform properties; encoding of values; and a summarization of the storage of ink.
While described with respect to the storage of ink, it is appreciated that the storage structures defined herein may be applied to non-ink items as well. For the purposes of this disclosure, ink objects are used as an example. Other objects reflecting information having properties may equally be used as well but are omitted for simplicity. For example, the storage structures may be applied to text (with properties including bold, font face, underline, margin settings and the like), graphics (with properties including modifications), non-modifiable information with subsequent modifications (for example, non-modifiable images with properties comprising subsequent comments), displayed information, and the like. The transform aspects described herein may be applied to the various objects and are considered within the scope of the present invention.
Characteristics and Storage of Ink
The present invention supports the storage of electronic ink and/or properties or other data associated with electronic ink. Ink as used herein refers to electronic ink. Ink refers to a sequence of strokes, where each stroke is comprised of a sequence of points. The points may be represented using a variety of known techniques including Cartesian coordinates (X, Y), polar coordinates (r, Θ), and other techniques as known in the art.
As known to users who use ink pens, physical ink (the kind laid down on paper using a pen with an ink reservoir) may convey more information than a series of coordinates connected by line segments. For example, physical ink can reflect pen pressure (by the thickness of the ink), pen angle (by the shape of the line or curve segments and the behavior of the ink around discreet points), and the speed of the nib of the pen (by the straightness, line width, and line width changes over the course of a line or curve).
To provide the look and feel of physical ink, the exemplary disclosed system and method store ink strokes and properties associated with the ink strokes to more fully render ink. In some embodiments, ink may be stored as a series or set of strokes and a series or set of properties. In other embodiments, ink may be stored with a complex series of properties in which the properties have properties of their own. Properties of the ink may include, for example, color, width, pressure between the stylus and tablet, and angle between the stylus and tablet, and pen shape and the like. While these properties may suffice for many applications, embodiments of the present invention provide for the extensible storage of custom properties (and other data) generated by applications. All strokes and values may be stored directly with excess information. However, alternative embodiments reflect considerations that eliminate excess information when possible or practicable.
One of these properties may include a mapping of a coordinate system to another. For example, ink may be stored in its original coordinate system. The ink may be associated with a transform mapping from the original coordinate system to another coordinate system. In further embodiments, the mapping may be altered to reflect the application of the ink to further coordinate systems.
As a part of the ink object, a transform mapping may be stored to represent the transform of the ink in its native coordinates to a virtual ink space. At a later time, the mapping may be used to transform the ink. In further embodiments, a second transform that maps coordinates from the virtual ink space to an output (for example, a printer, display, graphical file, handwriting recognition system, and the like) may be combined with the original mapping to the virtual ink space. The combination of the mappings may be applied to the ink in its native coordinates to directly transform the ink into a final coordinate system. It is appreciated that further combinations of mappings are realizable as well.
Terms
Ink—A sequence or set of strokes with properties. A sequence of strokes may include strokes in an ordered form. The sequence may be ordered by the time captured or by where the strokes appear on a page. Other orders are possible. A set of strokes may includes sequences of strokes or unordered strokes or any combination thereof
Stream—A sequence of strokes that may or may not include properties that comprises a data structure.
Ink object—A data structure storing a stream with or without properties.
Stroke—A sequence or set of captured points. For example, when rendered, the sequence of points may be connected with lines. Alternatively, the stroke may be represented as a point and a vector in the direction of the next point. In short, a stroke is intended to encompass any representation of points or segments relating to ink, irrespective of the underlying representation of points and/or what connects the points.
Point—Information defining a location in space. For example, the points may be defined relative to a capturing space (for example, points on a digitizer), a virtual ink space (the coordinates in a space into which captured ink is placed), and/or display space (the points or pixels of a display device).
Space—A context in which objects have meaning. For example, a digitizer space may include the capturing of ink (or other information). A rendering space may refer to the context of determining how information is to be rendered. A virtual ink space may be considered to exist between the digitizer space and the rendering space.
Virtual Ink Space—A framework to which all ink strokes relate. The framework may include a two- or three- (or more) dimensional shape. In one example, the framework may include a unit size square. In another example, the framework may include a defined rectangle, referred to as an ink space rectangle. While some ink strokes may extend outside of the framework, the framework may be used as a starting point for rendering purposes including dimensioning for a printer or a display or subsequent processing by, for example, a handwriting recognition system, or the like. In one aspect, the virtual ink space is a norm to which ink strokes may be spatially defined.
Ink Space Rectangle—a defined rectangle to which ink may be referenced. For example, when ink is captured, the mapping to the virtual ink space may include its relation to the ink space rectangle.
Transform Table and Transform Block—A mapping from one coordinate set to another coordinate set. The mapping may include equations, coefficients, from and to rectangles, or any combinations of these as well as others. The mapping may be provided by itself, in combination with an ink object, in combination with other mappings, or in combination with other mappings in an ink object. When used in combination with an ink object, the mapping may be specified in a transform block. When used with other transform blocks, the transform blocks may be combined into a transform table.
Global Ink Properties—These are properties that apply to a stroke or set of strokes unless otherwise defined. For example, a selected ink color may be blue. By setting all strokes to blue, the default color of the strokes would be blue.
Local Ink Properties—These are properties that apply to a specific stroke (or data point or data points). For example, while a global ink property may be blue, a specific stroke may be set to red. Some local ink properties may be interpreted, in some cases, as global properties as they affect subsequently encountered strokes in an ink object. It is noted that properties may or may not be labeled as global or local. In some examples, the created data structure defines the scope of the properties.
Render—The process of determining how text, graphics, and/or ink is to be displayed, whether on a screen or printed, or output into another file format.
General Purpose Computer
A basic input/output system 160 (BIOS), containing the basic routines that help to transfer information between elements within the computer 100, such as during start-up, is stored in the ROM 140. The computer 100 also includes a hard disk drive 170 for reading from and writing to a hard disk (not shown), a magnetic disk drive 180 for reading from or writing to a removable magnetic disk 190, and an optical disk drive 191 for reading from or writing to a removable optical disk 192 such as a CD ROM or other optical media. The hard disk drive 170, magnetic disk drive 180, and optical disk drive 191 are connected to the system bus 130 by a hard disk drive interface 192, a magnetic disk drive interface 193, and an optical disk drive interface 194, respectively. The drives and their associated computer-readable media provide nonvolatile storage of computer readable instructions, data structures, program modules and other data for the personal computer 100. It will be appreciated by those skilled in the art that other types of computer readable media that can store data that is accessible by a computer, such as magnetic cassettes, flash memory cards, digital video disks, Bernoulli cartridges, random access memories (RAMs), read only memories (ROMs), and the like, may also be used in the example operating environment.
A number of program modules can be stored on the hard disk drive 170, magnetic disk 190, optical disk 192, ROM 140 or RAM 150, including an operating system 195, one or more application programs 196, other program modules 197, and program data 198. A user can enter commands and information into the computer 100 through input devices such as a keyboard 101 and pointing device 102. Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner or the like. These and other input devices are often connected to the processing unit 110 through a serial port interface 106 that is coupled to the system bus, but may be connected by other interfaces, such as a parallel port, game port or a universal serial bus (USB). Further still, these devices may be coupled directly to the system bus 130 via an appropriate interface (not shown). A monitor 107 or other type of display device is also connected to the system bus 130 via an interface, such as a video adapter 108. In addition to the monitor, personal computers typically include other peripheral output devices (not shown), such as speakers and printers. In a preferred embodiment, a pen digitizer 165 and accompanying pen or stylus 166 are provided in order to digitally capture freehand input. Although a direct connection between the pen digitizer 165 and the processing unit 110 is shown, in practice, the pen digitizer 165 may be coupled to the processing unit 110 via a serial port, parallel port or other interface and the system bus 130 as known in the art. Furthermore, although the digitizer 165 is shown apart from the monitor 107, it is preferred that the usable input area of the digitizer 165 be co-extensive with the display area of the monitor 107. Further still, the digitizer 165 may be integrated in the monitor 107, or may exist as a separate device overlaying or otherwise appended to the monitor 107.
The computer 100 can operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 109. The remote computer 109 can be a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 100, although only a memory storage device 111 has been illustrated in
When used in a LAN networking environment, the computer 100 is connected to the local network 112 through a network interface or adapter 114. When used in a WAN networking environment, the personal computer 100 typically includes a modem 115 or other means for establishing a communications over the wide area network 113, such as the Internet. The modem 115, which may be internal or external, is connected to the system bus 130 via the serial port interface 106. In a networked environment, program modules depicted relative to the personal computer 100, or portions thereof, may be stored in the remote memory storage device.
It will be appreciated that the network connections shown are exemplary and other techniques for establishing a communications link between the computers can be used. The existence of any of various well-known protocols such as TCP/IP, Ethernet, FTP, HTTP and the like is presumed, and the system can be operated in a client-server configuration to permit a user to retrieve web pages from a web-based server. Any of various conventional web browsers can be used to display and manipulate data on web pages.
The stylus 204 may be equipped with one or more buttons or other features to augment its selection capabilities. In one embodiment, the stylus 204 could be implemented as a “pencil” or “pen”, in which one end constitutes a writing portion and the other end constitutes an “eraser” end, and which, when moved across the display, indicates portions of the display are to be erased. Other types of input devices, such as a mouse, trackball, or the like could be used. Additionally, a user's own finger could be the stylus 204 and used for selecting or indicating portions of the displayed image on a touch-sensitive or proximity-sensitive display. Consequently, the term “user input device”, as used herein, is intended to have a broad definition and encompasses many variations on well-known input devices such as stylus 204. Region 205 shows a feedback region or contact region permitting the user to determine where the stylus 204 as contacted the display surface 202.
In various embodiments, the system provides an ink platform as a set of COM (component object model) services that an application can use to capture, manipulate, and store ink. One service enables an application to read and write ink using the disclosed representations of ink. The ink platform may also include a mark-up language including a language like the extensible markup language (XML). Further, the system may use DCOM as another implementation.
An Example of Strokes of Ink
An exemplary ink object is shown in
From points 301 through 308, the width of the stroke has a first value. At point 308, the width of the stroke changes to a second value. This may have been because the user increased the pressure between the stylus 204 tip and the display surface 202, because the angle between the stylus 204 and the tablet changed, because the stylus 204 was rotated and projected a different cross section of the stylus 204's nib, or the like. The stroke then continues through point 316 with the second stroke width. In an alternate embodiment, a user started the stroke with a first line width and selected a different line width at point 308 to complete the stroke. In a further embodiment, two strokes may form the ink object as shown in
In a further embodiment, the ink of
Next, the ink object may be stored (or transmitted or displayed or the like). The ink object stroke may be represented as a single stroke with varying line widths and colors. Alternatively, the ink object may be stored as a variety of strokes having a few data points in which each stroke has its own set of properties. Third, the ink object may be stored as short strokes between points. In short, the ink object may represent a stroke in a variety of forms.
Transforming Ink
Ink objects may be created with a number of different input sources. The input sources may include a variety of tablets with different tablet resolutions. The different tablet resolutions may result in ink drawn on a screen be rendered incorrectly when the created ink is ported to and displayed on a tablet having a different resolution or screen size. To adjust the ink to a common size, a set of transform properties (or transforms) may be stored to indicate how the ink object is to be adjusted to a common space.
As described above, ink may be captured in a variety of ways. The ink may be transformed larger or smaller, rotated, translated, warped, and the like. Along these lines, ink may need to be transformed from its native coordinate system to a different coordinate system. For example, a tablet may capture ink in a first resolution, transform the ink to a second resolution, and output the ink in the second resolution to an application.
Blocks 406, 407, 407, and 409 represent transformation from the initial coordinate sets of tablets 401, 403, 404, and 402, respectively, to the virtual ink space. The ratio for mapping tablet 401 to the virtual ink space by the transform 406 may be 1:1 for both the X and Y directions with the origin of tablet 401 placed at the at point A in virtual ink space 405. Note that points in the X direction from the tablet 401 exceed the length of the rectangle 405. The ratio for mapping tablet 403 to the virtual ink space by the transform 407 may be 1:1 for both the X and Y directions with the origin of tablet 403 placed at the at point B in rectangle 405. The ratio for mapping tablet 404 to the virtual ink space by the transform 408 may be 1:1 for both the X and Y directions with the origin of tablet 404 placed at the at point A in rectangle 405. The ratio for mapping tablet 402 to the virtual ink space by the transform 409 may be 1000:400 (or 1000/400:1 or 5:2 or 5/2:1) for both the X and Y directions with the origin of tablet 402 placed at the point B in rectangle 405.
Tablet information 502 may be obtained and parsed in step 503. Alternatively, tablet information 502 may be obtained and added as a transform mapping property in step 505. Next, in step 507, the data structure is stored. Here, the storage step 507 is considered optional as other things may occur to the created ink object including, but not limited to, the inclusion of additional transformations in the ink object. Alternatively, the data structure may be forwarded to another device, displayed, further manipulated, and the like. Co-pending U.S. Ser. Nos. 09/852,799 and 09/870,478 disclose various tagged structures, which are incorporated by reference.
Next, in step 804, a stroke is added to the ink object. In an alternative embodiment, strokes may be added as a group to the ink object. In step 805, the system determines whether an event has occurred that signals the end of the ink stroke. This event may be a “pen up” event or any other event that may indicate that no more strokes are to be added to the ink object. In an alternative embodiment, the ink object may have strokes added even after the pen up event or alternative event.
In step 806, a transform mapping may be applied to the strokes. For example, if a tablet has a high resolution and the ink object is not to store coordinates in such a high resolution, an initial transform may be applied to the stroke or strokes in the ink object in step 806.
In step 807, the ink object is finished. The finished ink object may be stored or otherwise handled. For example, the stroke or strokes may be transformed in step 808. Also, the ink object may be rendered in step 809. The steps 806, 808, and 809 are optional in this process as shown by their dotted boxes. Further, the definition 803 of the transform or transforms to be applied to ink strokes may be determined after the ink strokes have been added to the ink object.
Data Structures for Storing Ink and Transform Mappings
An ink object is one of a variety of structures for storing ink.
When more than one property block occurs, it may be stored with other property blocks in a property table. The specific property blocks may be specified by an index referencing a specific property block or a default property block. Strokes 3910 and 5913 do not have immediately preceding indices. In one example, this may indicate that strokes 3910 and 5913 are to have properties specified by the default property block (not shows). In an alternate example, the strokes 3910 and 5913 use the most recent preceding index. Stroke 3910 would use index 808. Stroke 5913 would use index 911. Eliminating the recitation of an index for strokes 3910 and 5913 helps reduce the size of the ink object by the space that would have been consumed by separate indices for strokes 3810 and 5813.
Here, the identifier 1001 is generally referred to as a tag (or TAG or Tag). A “tagged” structure, as shown in
The structure as shown in
One benefit of placing the size after the tag itself is that applications that do not recognize the tag may know, by reading the next portion of information (the size block 1002, 1005, 1009), the length of data needed to skip over to arrive at the next tag or end of the ink data structure.
As to the specification of size of following data or the count of items in following data, it is appreciated that one may use either of the two ways of specifying information. For simplicity, the following description includes the use of size information. In some instances, count information is also shown. However, where only size information is shown, count information may readily be specified in place of or in addition to the size information.
As applied to ink, the tagged data structure of
The “tag” describing the “data” indicates whether the “data” contains tagged structures or even how many tagged structures. For example, custom properties are considered opaque to the present system since they are application-defined and thus only contain data. However, a stroke may have one or more stroke properties, which are also represented as tagged structures.
Ink properties may be defined to minimize or eliminate redundant information. In simple streams, there may be no ink properties. However, if there are ink properties, then it is preferable that they appear before any strokes so that they may apply to all strokes when needed. It is appreciated that the properties may be placed after the strokes as well. A number of global properties may be used. More or less global properties may be defined and used as needed.
With respect to ink objects, common properties appear. The properties may be grouped into transformation properties, drawing attributes properties, metrics properties, and stroke description properties. Other properties may be defined and used as well. Also, not all (if any) of the specific above-identified properties are required to practice the invention. Sample implementations of the above common properties are shown. Other properties are addressed in greater detail in co-pending U.S. Ser. Nos. 09/852,799 and 09/870,478, which are incorporated by reference.
Transform Properties
One may use the identifier of TAG_TRANSFORM_TABLE as the identifier 1101 to identify the transform table 1100. The size or count of the table may follow 1102. The size of the table may be is equal to the sum of the sizes of all transform blocks. The count may be equal to the number of blocks 1104, 1108 in the transform table 1100. Each transform block 1104, 1108 may include a transform block identifier 1103, 1107, a size or count field 1105, 1109 and a data field 1106, 1110.
To transform a point (X, Y) in two dimensions to a new point (X′, Y′), one may use the following two equations:
X′=xM11+yM12+Dx (1)
Y′=xM21+yM22+Dy (2)
The two equations provide a general solution in two dimensions for both rotation and translation of a point or points as based on the transformation matrix of six coefficients, namely M11, M12, M21, M22, and Dx and Dy (M11, M12, M21, and M22 being the rotational and scalar coefficients and Dx and Dy being the translational coefficients. A matrix of the six coefficients may take the form of:
M11 M12 Dx
M21 M22 Dy
A general equation for three dimensions may be given by:
X′=xM11+yM12+zM13+Dx (3)
Y′=xM21+yM22+zM23+Dy (4)
Z′=xM31+yM32+zM33+Dz (5)
A specific solution without rotation for two dimensions may be given by:
X′=xM11+Dx (6)
Y′=yM22+Dy (7)
The following description relates to transforms in two dimensions. It is appreciated that any n-dimension transforms may be used.
The specification of the six coefficients for the transform properties of equations 1 and 2 may be preferable to only specifying the four coefficients of equations 6 and 7 due to the fact that tablets (and/or capture systems may orient captured ink differently, for example, the origin being at the top left corner of a screen as opposed to the bottom left of a screen). On the other hand, specifying only four coefficients takes less space.
In one example, if the size of the four or six coefficients is constant (as opposed to the actual values of the coefficients), the size or count fields 1105, 1109 may be eliminated. Further, a transform table containing only one transform block is a special case. As with other properties in which there is only one block, the table tag 1101 and size/count 1102 for the table may be omitted and the entire table may be replaced by a single transform block.
In the simplest case, where the capturing environment and the rendering environment have no transformations between them, as well as in cases where scaling and transforms have been applied outside of a native capture environment, no transform tables may be created.
To assist in the transformation to a common coordinate space, an ink space rectangle that defines a virtual coordinate space (or virtual ink space) for receiving ink may be specified. One tag that may be used includes TAG_INK_SPACE_RECT, which identifies the ink space rectangle when present in the stream. This rectangle may be, for example, rectangle 405 from
As described above in some embodiments, transforms may be combined prior to application to ink in a first coordinate system. The following is an example of how two two-dimensional mappings may be combined into a single mapping. It is appreciated that more mappings in N dimensions may be combined as well but are not shown for simplicity.
A first transformation mapping may be given by:
X′=ax+by+c (8)
Y′=dx+ey+f (9)
A second transformation mapping may be given by:
X″=gx′+hy′+i (10)
Y″=jx′+ky′+m (11)
These two mappings of equations may be expressed as:
X″=g(ax+by+c)+h(dx+ey+f)+i (12)
Y″=j(ax+by+c)+k(dx+ey+f)+m (13)
Equations 12 and 13 simplify to:
X″=(ga+hd)x+(gb+he)y+gc+hf+i (14)
Y″=(ja+kd)x+(jb+ke)y+jc+kf+m (15)
These equations may also be represented in matrix form with equations 8 and 9 as
Equations 10 and 11 as
and equations 14 and 15 as
Accordingly, having the coefficients for a first mapping and a second mapping may be combined. The resulting mapping may then be combined with other mappings or applied to ink to transform the ink.
A number of tags may be used to indicate the type of transform to be applied to ink. The following table provides a list of tags and information relating to the coefficients for the transform. The values having no value (or zero as a value) may have a placeholder in the matrix (e.g., 0) or the placeholder may be eliminated. Eliminating the placeholder further reduces the size of the data structure storing the ink.
Of course, other tags are possible that further define additional sets of transforms.
Transform Index
If only one transform is to be applied to all strokes in an ink object, then a transform block 1104 with identifier 1103, size/count field 1105, and coefficients 1106 may be specified. If more than one transform is specified in an ink object, the ink object may use an index to relate a stroke or series of strokes back to a specific transform (for example in a transform block). The transform index (which may be specified with the identifier TAG_TIDX) assigns a transform block to a stroke. A transform index may be followed by an index value that specifies the entry in the transform table. All strokes in the stream from that point on may use the specified transform block until the next transform index is encountered in the stream.
In an alternate embodiment, if there is no transform index in the stream somewhere before the stroke, it may be assumed that this stroke should use the 0th transform block in the transform table. And if there is no transform table in the stream, then no transforms should be applied to any stroke.
Encoding of Values
To further assist with the storage of ink, the content of an ink object may be serialized as described in U.S. Ser. Nos. 09/852,799 and 09/870,478, which are expressly incorporated by reference. Also, the X and Y data may be compressed. A number of encoding strategies and compression methods may be used alone or in combination.
Sizes of Tags and Numbers
At the most basic level, the ink object may be composed of numbers. Even tags may be considered indexes, which are just small integer numbers. In fact, most of the time these numbers are small enough that they could be represented by a single byte if there was a way of determining when a byte represented a single number and when it was just part of a bigger number. In some embodiments, no encoding is used. In other embodiments, it may be possible to take advantage of this observation by encoding numbers using a multi-byte encoding technique.
Multi-byte encoding makes it possible to represent small numbers in one byte, larger numbers in two bytes and very large numbers in however many bytes are necessary. This means that tags, which usually have a value less than 100, are stored as a single byte and sizes, which may be small or large, are stored in the most efficient manner. In effect, multi-byte encoding may be a compression technique.
Various types of multi-byte encoding are known. An example of multi-byte encoding is shown and works as follows:
In other words, the system handles information such that:
In general, bytes are processed until a byte with the most significant bit clear may be encountered. For example, the first number encountered may be the ink object identifier number. For version 1.0 this value may be “0” and can be encoded in a single byte. The next number may be the size of the stream following the size value, and for small ink objects as in the first example this will also be encoded in a single byte. However, if the stream may be long this value can grow as large as necessary. For example, a multi-byte encoded number of 10 bytes can represent a 64-bit number.
This same process may be applied to “tags” and other values in the stream. In general since “tags” are small integer indexes, they too may be one byte encoded.
Multi-Byte Encoding of Signed Numbers
Multi-byte encoding as described above works well for positive integers. However, in some cases it may be necessary to store signed numbers. For example, the coordinates of a point may be positive or negative depending on where the application situates the origin.
To multi-byte encode a signed number, the absolute value of the signed number may be determined, the absolute value then may be shifted left by 1 bit, and the sign of the original number may be stored in the list significant bit.
Using the technique set forth above, the signed numbers with absolute values are handled as follows:
Further, ink may be compressed using known compression algorithms (for example, using Huffman compression systems and the like).
A Summarization of the Storage of Ink
A transform mapping may be stored in an ink object. The transform mapping permits the ink object to be stored in a first set of coordinates and later transformed to a second set of coordinates when needed.
Although the invention has been defined using the appended claims, these claims are exemplary in that the invention may be intended to include the elements and steps described herein in any combination or sub combination. Accordingly, there are any number of alternative combinations for defining the invention, which incorporate one or more elements from the specification, including the description, claims, and drawings, in various combinations or sub combinations. It will be apparent to those skilled in the relevant technology, in light of the present specification, that alternate combinations of aspects of the invention, either alone or in combination with one or more elements or steps defined herein, may be utilized as modifications or alterations of the invention or as part of the invention. It may be intended that the written description of the invention contained herein covers all such modifications and alterations. For instance, in various embodiments, a certain order to the data has been shown. However, any reordering of the data is encompassed by the present invention. Also, where certain units of properties such as size (e.g., in bytes or bits) are used, any other units are also envisioned.
This application is a divisional of prior U.S. application Ser. No. 09/891,512, filed Jun. 27, 2001. This application is related to U.S. Application No. 60/212,825, entitled “Methods for Classifying, Anchoring, and Transforming Ink Annotations”, filed Jun. 21, 2000, to U.S. application Ser. No. 09/750,288, entitled “Classifying, Anchoring, and Transforming Ink”, filed Dec. 29, 2000, to U.S. application Ser. No. 09/852,799, entitled “Serial Storage of Ink and Its Properties”, filed May 11, 2001, and to U.S. application Ser. No. 09/870,478, filed Jun. 1, 2001, entitled “Information Storage Using Tables and Scope Indices”, each of whose contents is expressly incorporated herein by reference as to their entireties.
Number | Name | Date | Kind |
---|---|---|---|
4156237 | Okata et al. | May 1979 | A |
4521770 | Rhyne | Jun 1985 | A |
4672559 | Jansson et al. | Jun 1987 | A |
4709348 | Horn et al. | Nov 1987 | A |
4786764 | Padula et al. | Nov 1988 | A |
5091964 | Shimomura | Feb 1992 | A |
5146552 | Cassorla et al. | Sep 1992 | A |
5148155 | Martin et al. | Sep 1992 | A |
5239466 | Morgan et al. | Aug 1993 | A |
5283557 | Memarzadeh | Feb 1994 | A |
5349648 | Handley | Sep 1994 | A |
5389745 | Sakamoto | Feb 1995 | A |
5434965 | Matheny et al. | Jul 1995 | A |
5455901 | Friend et al. | Oct 1995 | A |
5465325 | Capps et al. | Nov 1995 | A |
5473742 | Polyakov et al. | Dec 1995 | A |
5481275 | Mical et al. | Jan 1996 | A |
5502461 | Okamoto et al. | Mar 1996 | A |
5509663 | Otake et al. | Apr 1996 | A |
5528003 | Bodin et al. | Jun 1996 | A |
5534893 | Hansen et al. | Jul 1996 | A |
5537489 | Sinden et al. | Jul 1996 | A |
5548092 | Shriver | Aug 1996 | A |
5572643 | Judson | Nov 1996 | A |
5613019 | Altman et al. | Mar 1997 | A |
5625833 | Levine et al. | Apr 1997 | A |
5632022 | Warren et al. | May 1997 | A |
5636337 | Boenke et al. | Jun 1997 | A |
5646650 | Miller et al. | Jul 1997 | A |
5666139 | Thielens et al. | Sep 1997 | A |
5680480 | Beernink et al. | Oct 1997 | A |
5680636 | Levine et al. | Oct 1997 | A |
5682439 | Beernink et al. | Oct 1997 | A |
5687331 | Volk et al. | Nov 1997 | A |
5708825 | Sotomayor | Jan 1998 | A |
5717879 | Moran et al. | Feb 1998 | A |
5727129 | Barrett et al. | Mar 1998 | A |
5729687 | Rothrock et al. | Mar 1998 | A |
5737599 | Rowe et al. | Apr 1998 | A |
5740273 | Parthasarathy et al. | Apr 1998 | A |
5745116 | Pisutha-Arnond | Apr 1998 | A |
5760773 | Berman et al. | Jun 1998 | A |
5778404 | Capps et al. | Jul 1998 | A |
5790818 | Martin | Aug 1998 | A |
5801687 | Peterson et al. | Sep 1998 | A |
5818456 | Cosman et al. | Oct 1998 | A |
5821925 | Carey et al. | Oct 1998 | A |
5832263 | Hansen et al. | Nov 1998 | A |
5838914 | Carleton et al. | Nov 1998 | A |
5845262 | Nozue et al. | Dec 1998 | A |
5867593 | Fukuda et al. | Feb 1999 | A |
5877757 | Baldwin et al. | Mar 1999 | A |
5889523 | Wilcox et al. | Mar 1999 | A |
5893126 | Drews et al. | Apr 1999 | A |
5893132 | Huffman et al. | Apr 1999 | A |
5918236 | Wical | Jun 1999 | A |
5920647 | Nowlan et al. | Jul 1999 | A |
5920694 | Carleton et al. | Jul 1999 | A |
5931912 | Wu et al. | Aug 1999 | A |
5933140 | Strahorn et al. | Aug 1999 | A |
5937416 | Menzel | Aug 1999 | A |
5948040 | DeLorme et al. | Sep 1999 | A |
5950214 | Rivette et al. | Sep 1999 | A |
5953735 | Forcier | Sep 1999 | A |
5963205 | Sotomayor | Oct 1999 | A |
5978818 | Lin | Nov 1999 | A |
5983248 | De Rose et al. | Nov 1999 | A |
5986665 | Wrey et al. | Nov 1999 | A |
6005987 | Nakamura et al. | Dec 1999 | A |
6011537 | Slotznick | Jan 2000 | A |
6012055 | Campbell et al. | Jan 2000 | A |
6018334 | Eckerberg et al. | Jan 2000 | A |
6018342 | Bristor | Jan 2000 | A |
6018742 | Herbert, III | Jan 2000 | A |
6028649 | Faris et al. | Feb 2000 | A |
6035075 | Inoue et al. | Mar 2000 | A |
6035330 | Astiz et al. | Mar 2000 | A |
6049812 | Bertram et al. | Apr 2000 | A |
6052514 | Gill et al. | Apr 2000 | A |
6054990 | Tran | Apr 2000 | A |
6081829 | Sidana | Jun 2000 | A |
6088481 | Okamoto et al. | Jul 2000 | A |
6091930 | Mortimer et al. | Jul 2000 | A |
6094197 | Buxton et al. | Jul 2000 | A |
6101280 | Reynolds | Aug 2000 | A |
6118437 | Fleck et al. | Sep 2000 | A |
6122649 | Kanerva et al. | Sep 2000 | A |
6128007 | Seybold | Oct 2000 | A |
6157381 | Bates et al. | Dec 2000 | A |
6167376 | Ditzik | Dec 2000 | A |
6181344 | Tarpenning et al. | Jan 2001 | B1 |
6195679 | Bauersfeld et al. | Feb 2001 | B1 |
6195694 | Chen et al. | Feb 2001 | B1 |
6199082 | Ferrel et al. | Mar 2001 | B1 |
6201528 | Lucas et al. | Mar 2001 | B1 |
6205455 | Umen et al. | Mar 2001 | B1 |
6230171 | Pacifici et al. | May 2001 | B1 |
6239792 | Yanagisawa et al. | May 2001 | B1 |
6262719 | Bi et al. | Jul 2001 | B1 |
6271840 | Finseth et al. | Aug 2001 | B1 |
6279005 | Zellweger | Aug 2001 | B1 |
6279014 | Schilit et al. | Aug 2001 | B1 |
6289362 | Van Der Meer | Sep 2001 | B1 |
6301590 | Siow et al. | Oct 2001 | B1 |
6321244 | Liu et al. | Nov 2001 | B1 |
6326970 | Mott et al. | Dec 2001 | B1 |
6331867 | Eberhard et al. | Dec 2001 | B1 |
6332039 | Bando et al. | Dec 2001 | B1 |
6335727 | Morishita et al. | Jan 2002 | B1 |
6340967 | Maxted | Jan 2002 | B1 |
6356287 | Ruberry et al. | Mar 2002 | B1 |
6369811 | Graham et al. | Apr 2002 | B1 |
6373490 | Bendiksen et al. | Apr 2002 | B1 |
6384847 | Rabenhorst | May 2002 | B1 |
6389434 | Rivette et al. | May 2002 | B1 |
6393422 | Wone | May 2002 | B1 |
6397233 | Okawa et al. | May 2002 | B1 |
6405221 | Levine et al. | Jun 2002 | B1 |
6421065 | Walden et al. | Jul 2002 | B1 |
6446110 | Lection et al. | Sep 2002 | B1 |
6460058 | Koppolu et al. | Oct 2002 | B2 |
6486895 | Robertson et al. | Nov 2002 | B1 |
6490603 | Keenan et al. | Dec 2002 | B1 |
6529920 | Arons et al. | Mar 2003 | B1 |
6535294 | Arledge, Jr. et al. | Mar 2003 | B1 |
6539370 | Chang et al. | Mar 2003 | B1 |
6549220 | Hsu et al. | Apr 2003 | B1 |
6549675 | Chatterjee | Apr 2003 | B2 |
6560621 | Barile | May 2003 | B2 |
6563503 | Comair et al. | May 2003 | B1 |
6571295 | Sidana | May 2003 | B1 |
6642458 | Panagrossi, III et al. | Nov 2003 | B2 |
6720977 | Bourdev et al. | Apr 2004 | B1 |
6909430 | Dresevic et al. | Jun 2005 | B2 |
20020013795 | Dresevic et al. | Jan 2002 | A1 |
20020097261 | Gottfurcht et al. | Jul 2002 | A1 |
Number | Date | Country |
---|---|---|
902379 | Mar 1999 | EP |
1016983 | Jul 2000 | EP |
11327789 | Nov 1999 | JP |
WO 9620908 | Jul 1996 | WO |
WO 9722109 | Jun 1997 | WO |
WO 9806054 | Feb 1998 | WO |
WO 8701481 | Mar 1998 | WO |
WO 9809446 | Mar 1998 | WO |
WO 9949383 | Sep 1999 | WO |
Number | Date | Country | |
---|---|---|---|
20050105946 A1 | May 2005 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09891512 | Jun 2001 | US |
Child | 11019392 | US |