With the advent of digital photography and the world-wide-web, there has been an exponential growth in the creation and storage of digital photographic images. As the number of digital photographs taken and stored has grown, so too has the need for a convenient method of archiving, cataloguing, searching, and retrieving them. Modern methods of archiving and storing digital images typically require users to remember large amounts of information merely to locate photos that are of particular interest to them. For example, many users currently store their digital images in the hierarchical, directory-based file system structure that is native to personal computers. To find particular photos stored in such a hierarchical directory tree or structure, users must know the full pathname to the directory in which their photographs are stored.
There are other disadvantages to storing digital photographs in a hierarchical, directory-based file system. For example, cataloguing and storing groups of photos by categories such as vacation photos or wedding photos requires creating different directories for each of the desired categories. This further increases the amount of information that must be remembered in order to locate desired photos. In addition, in order to store photos in two or more overlapping categories, such as photos that include your favorite aunt and photos from your cousin's wedding, users must either store duplicate photographs, or master the concepts of directory trees and file pointers. While these are not difficult concepts for sophisticated computer users, they can be troublesome for less sophisticated users, thereby limiting the useful ways these users can store and retrieve digital photographs and photographic information.
The present invention relates to methods and apparatus for storing, cataloguing, managing, organizing, finding and displaying objects such as digital images. The invention includes methods for associating (“tagging”) fields of text and numeric data (“metadata”) with individual objects such as images or photos, storing the objects and associated metadata as records in a relational database, and selecting, sorting, organizing and finding the objects based on their tagged metadata content.
Default metadata tags can be specified, and new metadata tags can be defined and created through a tag editor by naming the tag, selecting its tag type, optionally selecting a graphical icon that represents the tag, and filling in any remaining fields or attributes that are unique to and define the tag type. Tags can be readily associated with an object by adding a record containing the tag information or metadata to a database, and relating the tagged metadata record to a database record containing the object or a pointer to the object. Tags can also be graphically associated with an object by, for example, dragging and dropping a graphical icon representing the tag onto a graphical representation of the object. In the latter case, database records containing the tag metadata are automatically created and related to the database record containing the target object or a pointer to the target object.
Once objects have been tagged with metadata, they can be searched for according to one or more tagged search criteria. When the objects to be search for are photos, these search criteria can include, but are not limited to, the date and time the photos were taken, textual information that is associated with the photos such as the names of the people who are in the photos or the places or events where the photos were taken, designations of the photos as favorite photos, and designation of the photos as photos that have been printed, shared with others, or archived on a certain date.
When a database is searched for objects that match one or more tagged search criteria, the matching objects can be viewed or arranged according to the degree to which they have associated metadata that matches the search criteria. In particular, objects that match all of the search criteria can be displayed first, followed by objects that match one or more of the search criteria, and finally by objects that match none of the search criteria. Objects in the different match groups can be differentiated from one another in the display area by visual cues, such as being displayed in front of different background colors or patterns. Thus, objects matching all of the search criteria can be displayed in front of a white background, while objects matching some of the search criteria can be displayed in front of a blue background, and objects matching none of the search criteria can be displayed in front of a gray background.
The distribution of the objects stored in the database can be displayed as a histogram along a timeline. Time bands can be set along the timeline to indicate a time period that can be used to search for matching objects in the database, or to limit the search results for a given tag search to objects having temporal metadata within the indicated time period. When the timeline is used to limit the search results for a tag search, the timeline displays not only the temporal distribution of all objects in the database over the indicated time period, but also the temporal distribution of all objects in the database matching the specified tag search criteria over the indicated time period.
In addition to timelines, the temporal distribution of objects in the database can be represented in a calendar view such that the days of the calendar indicate the number of objects having metadata associated with a given day of the week in a given week of the month. The calendar view can also be used to limit the search results for a tag search, in which case the calendar view will indicate all of the days of the month associated with objects that match all of the tagged search criteria, match some of the tagged search criteria, and match none of the tagged search criteria.
The details of one or more embodiments of the invention are set forth in the accompanying drawings and the description below. Other objects, features, and advantages of the invention will be apparent from the description and drawings, and the claims.
The present invention provides a method for users to organize and find digital images and photos by tagging them. Before being tagged, photos must be imported into a database where photographic metadata or information about the photos can be stored. While entire photos can be stored in the database, it is generally more efficient to store pointers to photos in the database rather than the photos themselves. Photos can be imported into the database from any of a number of devices or sources including, but not limited to, a digital camera, a flash memory device, a hard disk drive, a floppy drive, a CD-ROM, or a networked computer or file server. Once imported into the database, the photos can be tagged with one or more objects containing metadata that identifies the unique or important properties of the photo such as when or where the photo was taken, or who or what is the subject of the photo.
As shown in
Tags, and the metadata they contain, can be created and modified in a tag editor. The tag editor allows a user to specify a tag name and tag type, and to enter metadata in the form of tag attributes that can be stored in tags of the specified tag type. For convenience, tags can be divided into one or more tag categories. For example, in one embodiment tags are divided into people, events, places and miscellaneous tag categories. Tags in the different tag categories generally have different tag attributes to distinguish between themselves and tags in other tag categories. In general, a tag's attributes do not need to be filled in to associate a tag with a photo. The tag itself is a form of metadata that can be associated with the photo, regardless of whether the tag's possible attributes are also associated with the photo. However, when a tag's attributes are completely or partially filled in, more metadata is associated with the tagged photo, thereby making the photo easier to search for and find.
The people tag category includes default tag types for family and friends, and can be customized to include other groups of people such as business associates, classmates, co-workers, and neighbors, and particular individuals such as a spouse, daughter, or friend. Tags in the people category can contain attributes such as a person's name, sex, birthdate, anniversary, postal and/or email address(es), phone number(s), a sharing profile specifying which if any pictures can be shared with the people associated with the tag, and the relationships between the people associated with the tag and other tagged individuals.
The events tag category includes default tag types for parties and vacations, and can be customized to include tag types for particular types of events such as concerts, plays, shows and sporting events, and for particular events such as the 2002 Boston Marathon. In addition, tags in the events category can include pre-defined calendar events such as New Years Eve, and customized calendar events such as birthdays and anniversaries. Tags in the event tag category can contain attributes corresponding to the names, locations, and dates of the underlying events associated with the tags.
The places tag category can be customized to include tag types for particular places such as a home, an office, an art museum, or a vacation destination. Tags in the places tag category can contain attributes corresponding to specific locations that are associated with photos, including the name of the location (e.g., The Metropolitan Opera House), the names of the city, state, country and region of the world in which the photos were taken or which are the subject of the photos, and the geographical coordinates (e.g., longitude and latitude) for those places.
Finally, the miscellaneous tag category is as a customizable catchall for tags that cannot be easily grouped into a meaningful global category with other tags. Examples of miscellaneous tag types include tags for an apartment or home search, tags for artistic or photos, and tags for particular cars or types of cars. Miscellaneous tags can contain attributes corresponding to the name of the subject of the photo, and where and when the photo was taken.
As shown in
In general, photos in the database that have been tagged with one or more tags can be searched for and sorted by querying the database for all photos having tags that match one or more search tags or the metadata contained within the one or more search tags. These metadata can include, but are not limited to, data indicating whether photos are favorites; frequently viewed; similar to currently selected photos; untagged; taken on a particular day or recurring event; shared with or received from certain people; imported from certain places; and printed or exported on certain dates. In addition, the metadata can include the subject of the photo, whether a person, place, or event; as well as the place and/or event at which the photo was taken. For example, the photo of Lori R. in Legoland can be retrieved from the database by querying the database for all photos tagged with a Lori R. tag. This search will pull up all photos of Lori R., including the Legoland photo, regardless of where the photos were taken. Alternatively, the Legoland photo can be retrieved by searching the database for all photos tagged with a San Diego tag. This search will pull up all photos taken in or of San Diego, including the Legoland photo, regardless of who is in the photo. Finally, the Legoland photo can be retrieved by searching the database for all photos tagged with both a Lori R. tag and a San Diego tag. This search will pull up all photos taken in or of San Diego that include Lori R, including the Legoland photo.
The database search for photos that match certain tags or groups of tags can be graphically constructed by dragging various icons representative of tags 350 into a graphical query builder or lens 220, and searching the database for records with matching tags or metadata. When search criteria are applied to the photos in the database, the order in which the photos are displayed is updated so that “best match” photos or photos that match all of the search criteria are displayed at the top of an image area 100 in front of a first background color or pattern, while “close match” photos that match one or more but not all of the search criteria are displayed after the “best match” photos and are visually distinguished from them by, for example, being displayed in front of a second background color or pattern, and “no match” photos that fail to match any of the search criteria are displayed at the bottom of the image area in front of a third background color or pattern.
Perhaps the easiest search to conduct on tagged photos is a search for photos taken on a certain date, or within a certain period of time. As previously mentioned, among the metadata that can be stored with a photo is information indicating the date and time a photo was taken. This information is often automatically associated with a photo when the photo is created or when the photo is scanned into a digital scanner. If the photo is created on a digital camera, the camera will generally tag the photo with the date and time the photo was taken. If the photo is scanned into a digital scanner, the scanner will generally tag the photo with the date and time it was scanned. If for any reasons neither the digital camera nor digital scanner tags the photo with the date and time information, the database will tag the photo with the information when it is first imported.
As shown in
When the timeline 250 is used by itself to search for matching photos, the adjustable time bands 251 can be moved to find all photos in the database that are tagged with a date or timestamp that falls within the range indicated by the adjustable time bands 251. Photos falling within this range are designated “best match” photos, and can be viewed as such in image area 100. For example, the timeline 250 can be used by itself to find all photos taken between Jan. 1, 2000 and Feb. 28, 2000 by moving the adjustable time bands 251 to these two respective dates. The photos in the database that have been tagged with a timestamp falling between these two dates can be retrieved from the database, and displayed in the “best match” section of image area 100.
In addition to finding photos according to their timestamp, the timeline 250 can be used with other metadata to limit search tag results. For example, if the adjustable time bands 251 of timeline 250 indicate the period of interest extends from Jan. 1, 2000 to Feb. 28, 2000, searching the database for all photos having a San Diego tag will return the photo “Lori on the road at Legoland” as a “best match” photo, and display the photo in image area 100, only if the photo was taken sometime between Jan. 1, 2000 and Feb. 28, 2000. If the photo was taken outside of this time period, it would only appear as a “close match” photo in image area 100. When tag searches are conducted in conjunction with timeline 250, the timeline displays the total number of photos in the database per unit time period in a first color which may be a solid color, and the total number of photos in the database that match the tagged search criteria as “best” or “close” matches in a second color which may be a hatched pattern or color.
In one embodiment, the timeline 250 shown in
As shown in
The calendar view can also display the results of a tag search in the month-at-a-glance mode. When so used, each day in the calendar can indicate not only whether any photos were taken on that day, but whether the photos taken on that day fall into the “best match”, “close match”, or “no match” group with respect to the tagged search criteria. For example, if the Legoland photo described in
The particular group into which a set of photos taken on a given calendar day falls can be indicated on the calendar using the same color based indication scheme used to indicate matching photo groups that are displayed in the viewing area. Thus, calendar days containing one or more photos in the “best match” group can be presented as white squares, while calendar days containing one or more photos in the “close match” group and no photos in the “best match” group can be presented as blue squares, and calendar days containing no photos in either the “best match” or “close match” groups can be presented as gray squares.
As shown in
The map view can also be used in conjunction with a tag search. When so used, the map view will display not only the distribution of photos as a function of geographic location, but whether the photos taken at the various geographic locations fall in the “best match”, “close match”, or “no match” group with respect to the tagged search criteria. For example, if a search for all photos having an African tag were displayed in the map view, the map view would indicate that photos taken from the Kenya Safari fall into the “best match” group, while all of the other photos shown in
The map view can be varied in size and shape to accommodate the geographic extent of the photos that are either in the database or that are responsive to a tag search conducted on the photos in the database. Thus, if a map view is used to display or further search among database photos having a North American tag, the map view can be limited to a view of the North American continent. The map view can also be varied in size and shape by selecting particular regions of a map, such as the western region of the United States, or by zooming in and out of the currently displayed map region. Photos corresponding to particular locations within a map view, like San Diego, can be geographically found directly from the map view.
Once photos matching a given set of tags are found, they can be selected as a group, and various photo management functions such as printing, sharing, or exporting the photos to a slide show or to a photo album can be performed on the group. As a default, all photos in the “best match” group are selected when selecting photos that match a given set of tag search criteria. However, the default can be changed such that all photos in both the “close match” and “best match” groups are selected when selecting photos that match a given set of tag search criteria.
It should be noted that while the invention has been described in terms of managing, cataloguing, searching, and finding digital images and photographs, the invention can equally be used to manage, catalogue, search for and find other types of digital media such as video files, audio files, photo slide shows, and photo albums. These different types of media can be distinguished from one another with a tag of tag type media. The media tag, when applied to a media object, can graphically indicate the type of media object that is stored in the database.
As shown in
While the invention has been described as a computer program or algorithm, the invention can be implemented in digital electronic circuitry, or in computer hardware, firmware, software, or in any combinations of them. Apparatus of the invention can be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a programmable processor; and method steps of the invention can be performed by a programmable processor executing a program of instructions to perform functions of the invention by operating on input data and generating output. The invention can be implemented advantageously in one or more computer programs that are executable on a programmable system including at least one programmable processor coupled to receive data and instructions from, and to transmit data and instructions to, a data storage system, at least one input device, and at least one output device. Each computer program can be implemented in a high-level procedural or object-oriented programming language, or in assembly or machine language if desired; and in any case, the language can be a compiled or interpreted language. Suitable processors can include both general and special purpose microprocessors. Generally, a processor will receive instructions and data from a read-only memory and/or a random access memory. Generally, a computer will include one or more mass storage devices for storing data files; such devices include magnetic disks, such as internal hard disks and removable disks; magneto-optical disks; and optical disks. Storage devices suitable for tangibly embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, such as EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROM disks. Any of the foregoing can be supplemented by, or incorporated in, application-specific integrated circuits (ASICs).
While the invention has been described in terms of particular embodiments, it should be understood that other embodiments are possible as would be apparent to one of ordinary skill in the art. Accordingly, these and other embodiments are within the scope of the following claims.
This application claims the benefit of priority to U.S. application Ser. No. 10/198,618, filed Jul. 17, 2002, now U.S. Pat. No. 7,415,662, which claims the benefit of Ser. No. 10/052,213, filed Jan. 16, 2002, which claims the benefit of priority to U.S. application Ser. No. 09/774,523, filed Jan. 31, 2001, and U.S. provisional application Ser. No. 60/334,516 filed Oct. 31, 2001. U.S. application Ser. No. 09/774,523 claims priority to U.S. provisional application Ser. No. 60/261,897, filed Jan. 16, 2001, and U.S. provisional application Ser. No. 60/179,379, filed Jan. 31, 2000, the disclosure of which is incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
4888692 | Gupta et al. | Dec 1989 | A |
5214622 | Nemoto et al. | May 1993 | A |
5241671 | Reed et al. | Aug 1993 | A |
5260868 | Gupta et al. | Nov 1993 | A |
5421008 | Banning et al. | May 1995 | A |
5428776 | Rothfield | Jun 1995 | A |
5491626 | Williams et al. | Feb 1996 | A |
5515488 | Hoppe et al. | May 1996 | A |
5557747 | Rogers et al. | Sep 1996 | A |
5559942 | Gough et al. | Sep 1996 | A |
5579471 | Barber et al. | Nov 1996 | A |
5644766 | Coy et al. | Jul 1997 | A |
5649186 | Ferguson | Jul 1997 | A |
5664063 | Johnson et al. | Sep 1997 | A |
5668966 | Ono et al. | Sep 1997 | A |
5692175 | Davies et al. | Nov 1997 | A |
5706457 | Dwyer et al. | Jan 1998 | A |
5734888 | Li et al. | Mar 1998 | A |
5751286 | Barber et al. | May 1998 | A |
5761655 | Hoffman | Jun 1998 | A |
5787412 | Bosch et al. | Jul 1998 | A |
5796945 | Tarabella | Aug 1998 | A |
5813014 | Gustman | Sep 1998 | A |
5832495 | Gustman | Nov 1998 | A |
5842203 | D'Elena et al. | Nov 1998 | A |
5842218 | Robinson | Nov 1998 | A |
5844572 | Schott | Dec 1998 | A |
5847708 | Wolff | Dec 1998 | A |
5884298 | Smith et al. | Mar 1999 | A |
5898431 | Webster et al. | Apr 1999 | A |
5907324 | Larson et al. | May 1999 | A |
5924090 | Krellenstein | Jul 1999 | A |
5956730 | Burroughs et al. | Sep 1999 | A |
5966126 | Szabo | Oct 1999 | A |
6017157 | Garfinkle et al. | Jan 2000 | A |
6085205 | Peairs et al. | Jul 2000 | A |
6094657 | Hailpern et al. | Jul 2000 | A |
6115717 | Mehrotra et al. | Sep 2000 | A |
6148260 | Musk et al. | Nov 2000 | A |
6148354 | Ban et al. | Nov 2000 | A |
6195651 | Handel et al. | Feb 2001 | B1 |
6199099 | Gershman et al. | Mar 2001 | B1 |
6202061 | Khosla et al. | Mar 2001 | B1 |
6240423 | Hirata | May 2001 | B1 |
6246410 | Bergeron et al. | Jun 2001 | B1 |
6353823 | Kumar | Mar 2002 | B1 |
6370541 | Chou et al. | Apr 2002 | B1 |
6396963 | Shaffer et al. | May 2002 | B2 |
6401085 | Gershman et al. | Jun 2002 | B1 |
6408301 | Patton et al. | Jun 2002 | B1 |
6411313 | Conlon et al. | Jun 2002 | B1 |
6425017 | Dievendorff et al. | Jul 2002 | B1 |
6434546 | Williamowski et al. | Aug 2002 | B1 |
6442527 | Worthington | Aug 2002 | B1 |
6456307 | Bates et al. | Sep 2002 | B1 |
6466940 | Mills | Oct 2002 | B1 |
6504571 | Narayanaswami et al. | Jan 2003 | B1 |
6581102 | Amini et al. | Jun 2003 | B1 |
6587668 | Miller et al. | Jul 2003 | B1 |
6587856 | Srinivasan et al. | Jul 2003 | B1 |
6597800 | Murray et al. | Jul 2003 | B1 |
6598046 | Goldberg et al. | Jul 2003 | B1 |
6628899 | Kito | Sep 2003 | B1 |
6629104 | Parulski et al. | Sep 2003 | B1 |
6687878 | Eintracht et al. | Feb 2004 | B1 |
6738155 | Rosenlund et al. | May 2004 | B1 |
6760884 | Vertelney et al. | Jul 2004 | B1 |
6845370 | Burkey et al. | Jan 2005 | B2 |
6904427 | Hagiwara et al. | Jun 2005 | B1 |
6947959 | Gill | Sep 2005 | B1 |
6957205 | Liongosari | Oct 2005 | B1 |
6993723 | Danielson et al. | Jan 2006 | B1 |
7017162 | Smith et al. | Mar 2006 | B2 |
7020686 | Banatwala | Mar 2006 | B2 |
7028262 | Estrada et al. | Apr 2006 | B2 |
7034691 | Rapaport et al. | Apr 2006 | B1 |
7069259 | Horvitz et al. | Jun 2006 | B2 |
7076503 | Platt et al. | Jul 2006 | B2 |
7076504 | Handel et al. | Jul 2006 | B1 |
7082430 | Danielson et al. | Jul 2006 | B1 |
7103559 | Worthington | Sep 2006 | B2 |
7296032 | Beddow | Nov 2007 | B1 |
7298520 | Ohkubo et al. | Nov 2007 | B2 |
7363590 | Kerr et al. | Apr 2008 | B2 |
7415662 | Rothmuller et al. | Aug 2008 | B2 |
7472135 | Huuskonen | Dec 2008 | B2 |
20010047365 | Yonaitis | Nov 2001 | A1 |
20020054059 | Schneiderman | May 2002 | A1 |
20020054083 | Boreczky et al. | May 2002 | A1 |
20020055955 | Lloyd-Jones et al. | May 2002 | A1 |
20020059604 | Papagan et al. | May 2002 | A1 |
20020075324 | Combs et al. | Jun 2002 | A1 |
20020075330 | Rosenzweig et al. | Jun 2002 | A1 |
20020087546 | Slater et al. | Jul 2002 | A1 |
20020097259 | Marshall et al. | Jul 2002 | A1 |
20020140730 | Linsey et al. | Oct 2002 | A1 |
20020140820 | Borden | Oct 2002 | A1 |
20020149618 | Estrada et al. | Oct 2002 | A1 |
20020165753 | Worthington | Nov 2002 | A1 |
20020170040 | Idan | Nov 2002 | A1 |
20030084065 | Lin et al. | May 2003 | A1 |
20030154212 | Schirmer et al. | Aug 2003 | A1 |
20030167310 | Moody et al. | Sep 2003 | A1 |
20030200192 | Bell et al. | Oct 2003 | A1 |
20040002932 | Horvitz et al. | Jan 2004 | A1 |
20040030675 | Could | Feb 2004 | A1 |
20040078372 | Huuskonen | Apr 2004 | A1 |
20040078389 | Hamilton | Apr 2004 | A1 |
20050044066 | Hooper et al. | Feb 2005 | A1 |
20050044529 | Simons et al. | Feb 2005 | A1 |
20050050043 | Pyhalammi et al. | Mar 2005 | A1 |
20050057584 | Gruen et al. | Mar 2005 | A1 |
20050182752 | Rojer | Aug 2005 | A1 |
20050207645 | Nishimura et al. | Sep 2005 | A1 |
20080306921 | Rothmuller et al. | Dec 2008 | A1 |
Number | Date | Country |
---|---|---|
08030763 | Feb 1996 | JP |
Number | Date | Country | |
---|---|---|---|
20080306921 A1 | Dec 2008 | US |
Number | Date | Country | |
---|---|---|---|
60334516 | Oct 2001 | US | |
60261897 | Jan 2001 | US | |
60179379 | Jan 2000 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10198618 | Jul 2002 | US |
Child | 12190515 | US | |
Parent | 10052213 | Jan 2002 | US |
Child | 10198618 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09774523 | Jan 2001 | US |
Child | 10052213 | US |