Sélection de la langue

Search

Sommaire du brevet 2567631 

Énoncé de désistement de responsabilité concernant l'information provenant de tiers

Une partie des informations de ce site Web a été fournie par des sources externes. Le gouvernement du Canada n'assume aucune responsabilité concernant la précision, l'actualité ou la fiabilité des informations fournies par les sources externes. Les utilisateurs qui désirent employer cette information devraient consulter directement la source des informations. Le contenu fourni par les sources externes n'est pas assujetti aux exigences sur les langues officielles, la protection des renseignements personnels et l'accessibilité.

Disponibilité de l'Abrégé et des Revendications

L'apparition de différences dans le texte et l'image des Revendications et de l'Abrégé dépend du moment auquel le document est publié. Les textes des Revendications et de l'Abrégé sont affichés :

  • lorsque la demande peut être examinée par le public;
  • lorsque le brevet est émis (délivrance).
(12) Demande de brevet: (11) CA 2567631
(54) Titre français: AFFICHAGE DE TEXTURES GRAPHIQUES
(54) Titre anglais: DISPLAYING GRAPHICAL TEXTURES
Statut: Réputée abandonnée et au-delà du délai pour le rétablissement - en attente de la réponse à l’avis de communication rejetée
Données bibliographiques
(51) Classification internationale des brevets (CIB):
  • G06T 15/04 (2011.01)
(72) Inventeurs :
  • BROWNLEE, DAVID C. (Royaume-Uni)
  • PETERS, LESLIE (Royaume-Uni)
  • GETTMAN, DAVID (Royaume-Uni)
  • MORRIS, NICOLE (Royaume-Uni)
(73) Titulaires :
  • THREE-B INTERNATIONAL LIMITED
(71) Demandeurs :
  • THREE-B INTERNATIONAL LIMITED (Bahamas)
(74) Agent: SMITHS IP
(74) Co-agent:
(45) Délivré:
(86) Date de dépôt PCT: 2004-07-23
(87) Mise à la disponibilité du public: 2005-12-22
Licence disponible: S.O.
Cédé au domaine public: S.O.
(25) Langue des documents déposés: Anglais

Traité de coopération en matière de brevets (PCT): Oui
(86) Numéro de la demande PCT: PCT/GB2004/003199
(87) Numéro de publication internationale PCT: GB2004003199
(85) Entrée nationale: 2006-11-21

(30) Données de priorité de la demande:
Numéro de la demande Pays / territoire Date
10/864,816 (Etats-Unis d'Amérique) 2004-06-08

Abrégés

Abrégé français

L'invention porte sur un procédé d'affichage de textures graphiques qui consiste à déterminer si une mise à jour existe pour un élément de contenu particulier parmi un ou plusieurs éléments de contenu, chaque élément de contenu étant associé à une ou plusieurs textures; si une mise à jour existe pour l'élément de contenu particulier, à effectuer les étapes suivantes: déterminer une texture particulière parmi une ou plusieurs textures auxquelles les informations sont associées, obtenir la texture particulière, la texture particulière étant produite sur la base de l'élément de contenu particulier, et afficher la texture particulière.


Abrégé anglais


A method of displaying a graphical texture comprises determining whether an
update exists for a particular content element from among one or more content
elements, wherein each content element is associated with one or more
textures; if an update exists for the particular content element, performing
the steps of determining a particular texture from among the one or more
textures with which the information is associated; obtaining the particular
texture, wherein the particular texture is generated based on the particular
content element; and displaying the particular texture.

Revendications

Note : Les revendications sont présentées dans la langue officielle dans laquelle elles ont été soumises.


CLAIMS
1. A method of managing the display of a large number of graphical textures
wherein not all
the textures are visible at any one time, the method comprising the machine-
implemented steps
of:
creating and storing one or more pools of high-resolution textures in memory;
displaying the textures on polygons in a virtual three-dimensional
environment;
wherein one or more of the textures display informational content and deliver
informational content to a viewer of the three-dimensional environment,
wherein
one or more of these textures can be viewed at a high level of detail, wherein
one
or more of the textures have approximately similar dimensions, and wherein a
viewer can interact with one or more of the textures;
wherein an arrangement of the textures is defined in one or more sources, and
wherein
the informational content associated with the textures may derive from one or
more remote sources; and
wherein the virtual three-dimensional environment comprises one or more
channels and
wherein one or more of the textures displaying informational content are
aligned
along the channels.
2. A method according to claim 1, further comprising the steps of allocating,
for each
polygon, among one or more polygons at which one or more of the textures are
to be displayed, a
texture priority value; and assigning the texture priority value to an
associated texture.
3. A method according to claim 2, further comprising the step of determining
the texture
priority value based on whether a position of the associated texture is in
view, how far the
position is away from a viewer's position, and an angle relative to the
viewer's position.
4. A method of managing persistence of graphical textures used for display
wherein the
method comprises the machine-implemented steps of:
creating one or more caches of textures on a storage medium;
32

displaying the textures on polygons in a virtual three-dimensional
environment;
wherein many of the textures display informational content and deliver
informational
content to a viewer of the virtual three-dimensional environment, wherein one
or
more of these textures can be viewed at a high level of detail, wherein most
of
these textures have approximately similar dimensions, and wherein a viewer can
interact with one or more of these textures;
wherein the arrangement of the textures are defined in one or more sources
that are
separate from a machine that implements the method, and wherein the content
associated with the textures may derive from one or more remote sources;
wherein the virtual three-dimensional environment comprises one or more
channels and
wherein many of the textures displaying informational content are aligned
along
those channels; and
storing one or more textures to a cache on a storage medium for later
retrieval and display
within the virtual three-dimensional environment.
5. A method according to claim 4 further comprising the step of saving the
textures relevant
to a current virtual three-dimensional environment to a cache upon exit from
that virtual three-
dimensional environment.
6. A method according to claim 4 further comprising the step of saving the
textures after
each is generated or downloaded.
7. A method according to claim 4, 5 or 6 wherein the textures that are stored
relate to a
different virtual three-dimensional environment other than a currently
displayed virtual three-
dimensional environment.
8. A method according to any one of claims 4 to 7 further comprising the steps
of allocating
priority values to the textures to order the storage to the storage medium,
and using the priority
values when performing the storing step.
33

9. A method according to any one of the preceding claims further comprising
the steps of
compressing the textures before storing the textures in the cache and
uncompressing the textures
upon loading the textures from the cache.
10. A method according to any one of the preceding claims further comprising
the steps of
storing the textures in an additional cache formed in a first area of computer
main memory
between a second area of memory used to hold the textures for display and the
storage medium
used for the main cache.
11. A method according to claim 10 further comprising the steps of compressing
the textures
in the main memory cache and uncompressing the textures before copying the
textures to the
second area of memory used to hold the textures for display.
12. A method of managing updating of graphical textures used for display
wherein the
method comprises the machine-implemented steps of:
displaying the textures on polygons in a virtual three-dimensional
environment;
wherein many of the textures display informational content and deliver
informational
content to a viewer of the virtual three-dimensional environment, wherein one
or
more of these textures can be viewed at a high level of detail, wherein most
of
these textures have approximately similar dimensions, and wherein a viewer can
interact with one or more of these textures;
wherein the arrangement of the textures are defined in one or more sources
that are
separate from a machine that implements the method, and wherein the content
associated with the textures may derive from one or more remote sources;
wherein the virtual three-dimensional environment comprises one or more
channels and
wherein many of the textures displaying informational content are aligned
along
those channels;
determining whether an update exists for a particular content element from
among one or
more content elements, wherein each content element is associated with one or
more textures;
34

if any updates exists, updating the relevant texture or textures.
13. A method according to claim 12 further comprising the step of considering
a texture
which is not available locally on the machine that implements the method as
one which requires
updating.
14. A method according to claim 12 or 13 wherein a source content to texture
generation
pool is created which permits more than one source content element to be
processed
simultaneously.
15. A method according to claim 14 wherein entries in the texture generation
pool can be
used to provide a single update or generation of a texture, or a continual
stream of updates based
on information contained in the content elements.
16. A method according to claim 14 or claim 15 further comprising allocating a
live priority
to textures based on one or more criteria and reserving one or more generation
pool entries for
generating these textures from their content elements.
17. A method according to claim 16 further comprising determining the live
priority based on
whether the polygon displaying the texture is visible, or likely to become
visible in the very near
future.
18. A method according to claim 16 or claim 17 further comprising determining
the live
priority based on whether the source content for a texture contains
information which will cause
the texture to be updated dynamically.
19. A method according to any one of claims 12 to 18 further comprising the
step of
determining an order of priority for processing any updates for particular
content elements, and
updating the relevant textures according to that order.

20. A method according to any one of claims 12 to 19 in which a position of
one or more of
the textures within the virtual three-dimensional environment is changed.
21. A method according to any one of claims 12 to 20 in which one of the
textures is altered
as a result of a changing in a mapping of that texture to an associated
content source.
22. A method according to any one of claims 12 to 20 in which one of the
textures is altered
as a result of a change in an associated content source.
23. A method according to any one of claims 12 to 20 in which one of the
textures is altered
as a result of the content source containing an animation or other dynamic
information.
24. A method according to any one of claims 12 to 20 in which the texture is
altered as a
result of an interaction with the user or a characteristic of the user.
25. A method according to claim 24 in which the viewer characteristic may be
the age or
language preference of the viewer.
26. A method according to any one of claims 12 to 20 in which the texture is
altered as a
result of a change of the user's position and/or viewpoint within the virtual
three-dimensional
environment.
27. A method according to any one of claims 12 to 20 in which the texture is
altered based on
the status of the updating of the texture.
28. A method according to claim 27 in which the status is one of 'load
pending', 'generate
pending', 'load in progress', 'generate in progress', 'load failed', or
'generate failed'.
36

29. A method according to any one of claims 12 to 27 whereby a change in a
texture can
result in a new texture being generated.
30. A method according to any of claims 12 to 27 whereby a change in a texture
can result in
a new texture being downloaded from a remote source.
31. A method according to claims 1 and 12 further comprising the step of
reserving one or
more of the texture pool entries for actively generating textures.
32. A method according to claims 2 or 31 further comprising the steps of
reserving one or
more of the texture pool entries for actively generating textures, and
allocating the reserved
texture pool entries to high priority textures.
33. A method of managing graphical textures used for display wherein the
method comprises
the machine-implemented steps of:
displaying the textures on polygons in a virtual three-dimensional
environment;
having one or more lower resolution textures associated with each texture;
wherein many of the textures display informational content and deliver
informational
content to a viewer of the virtual three-dimensional environment, wherein one
or
more of these textures can be viewed at a high level of detail, wherein most
of
these textures have approximately similar dimensions, and wherein a viewer can
interact with one or more of these textures;
wherein the arrangement of the textures are defined in one or more sources
that are
separate from a machine that implements the method, and wherein the content
associated with the textures may derive from one or more remote sources;
wherein the virtual three-dimensional environment comprises one or more
channels and
wherein many of the textures displaying informational content are aligned
along
those channels; and
determining whether to display a lower resolution texture in place of a high-
resolution
texture based on one or more criteria.
37

34 A method according to claim 33, further comprising the step of storing the
low-resolution
textures on a mass storage system.
35. A method according to claim 33 or claim 34, further comprising the step of
downloading
a low-resolution texture corresponding to one or more of the high-resolution
textures via a
network.
36. A method according to claim 35, further comprising the steps of defining a
priority
ordering for the download of low-resolution textures and downloading low-
resolution textures
according to that priority.
37. A method according to claim 36, wherein the priority is based on the
viewer's location in
the virtual three-dimensional environment.
38. A method according to claim 12 or claim 33 further comprising generating
each low-
resolution texture at the same time as the corresponding high resolution
texture.
39. A method according to claim 1 and claim 33 wherein in addition one or more
larger pools
of corresponding lower-resolution textures are created.
40. A method according to any of the preceding claims wherein the content is
downloaded
over a network to a client computer system, organized and rendered using the
client computer
system after downloading.
41. A method according to any of the preceding claims further comprising the
steps of
downloading a complete texture to a client computer system over a network.
38

42. A method according to claim 41 further comprising allocating a priority
order to the
download of complete textures and downloading the complete textures in
accordance with that
priority.
43. A method according to any one of the preceding claims wherein the content
is owned or
controlled by more than one entity.
44. A method according to any one of the preceding claims further comprising
the step of
blocking the user from altering the location of textures within the virtual
three-dimensional
environment by interacting with the virtual environment.
45. A method according to any one of the preceding claims wherein the source
content
comprises one or more of internet pages, television screenshots, mobile phone
pages, game
screenshots, images, documents, or video content.
46. A method as recited in claim 2 and claim 36 wherein polygons having a
higher texture
priority are allocated entries in the high resolution texture pool, and some
of the remaining
polygons are allocated low-resolutions textures.
47. A method according to any one of the preceding claims wherein the method
further
comprises the steps of:
determining whether a polygon needs to be made available, wherein the polygon
is
associated with the particular texture;
if the step of generating the texture has completed, displaying the particular
texture;
if the step of generating the texture has not completed, displaying a second
particular
texture.
39

48. A method according to any one of the preceding claims wherein the method
further
comprises the steps of:
determining whether a polygon needs to be made available, wherein the polygon
is
associated with the particular texture;
if the texture is in memory, displaying the particular texture;
if the texture is not in memory, initiating a process to obtain that texture
into memory,
and displaying a second particular texture while that load is not complete.
49. A method according to claim 4 or claim 48 wherein the process of obtaining
the texture
comprises loading the texture from a local storage medium.
50. A method according to claim 48 wherein the process of obtaining the
texture comprises
downloading the texture from a network.
51. A method according to claim 4, claim 49 or claim 50 wherein a priority
value is allocated
to each texture for the purpose of loading textures and in which the priority
value is used in the
loading of textures.
52. A method according to claim 4 or claim 48 wherein one or more of the
textures relevant
to the current virtual three-dimensional environment which are present in a
cache are loaded
from the cache upon entry to that virtual three-dimensional environment.
53. A method according to claim 4 or claim 48 wherein the textures relevant to
the current
virtual three-dimensional environment which are present in a cache are loaded
on demand from
the cache.
54. The method according to any of claims 47 or 48, wherein the second
particular texture is
based on a previous version of the first particular texture.

55. The method according to any of claims 47 or 48, wherein the second
particular texture is
selected from an existing set of alternative textures not based on the first
particular texture.
56. A method as recited in any of claims 47 or 48, wherein the second
particular texture
comprises a high-resolution texture.
57. A method as recited in any of claims 47 or 48, wherein the second
particular texture
comprises a low-resolution texture.
58. A method according to claims 1 or 47 or 48 further comprising the steps
of:
creating one or more pools in memory dedicated to loading and generating
textures; and
creating a separate pool in memory for displaying textures.
59. A method according to claim 58 which further comprises the steps of:
detecting that the generation of a texture is complete;
determining that the generated texture is more optimal for display than at
least one of the
textures in the display pool;
determining the texture in the display pool that is least optimal for display
and replacing
its display texture pool entry with the generated texture;
making available for other textures the entry previously used for generating
in the
load/generate pool.
60. A computer-readable medium comprising one or more sequences of
instructions which,
when executed by one or more processors, cause the one or more processors to
perform the steps
of any one of the preceding claims.
61. A computer apparatus, comprising:
means for displaying a graphical image; and
41

means for performing the functions recited in the steps of any one of claims 1
to 59.
62. A computer apparatus, comprising:
one or more processors;
one or more memories communicatively coupled to the one or more processors;
and
one or more computer-readable media comprising one or more sequences of
instructions
which, when executed by one or more processors, cause the one or more
processors to perform the steps of any one of claims 1 to 59.
63. A computer program comprising one or more sequences of instructions which
can
perform the method of any one of claims 1 to 59.
42

Description

Note : Les descriptions sont présentées dans la langue officielle dans laquelle elles ont été soumises.


CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
DISPLAYING GRAPHICAL TEXTURES
FIELD OF THE INVENTION
[001] The present invention generally relates to computer graphics. The
invention relates
more specifically to displaying graphical textures.
BACKGROUND OF THE INVENTION
[002] Certain classes of computer graphics systems are required to rapidly
display large
numbers of different graphical textures in real time as a user is interacting
with the systems. For
example, co-pending application Ser. No. 10/727,799, filed 3 December 2003 of
David Gettman
et al., entitled "Information Display," describes in one aspect a browser for
navigating a virtual
three-dimensional environment that may comprise a virtual city in which
textures rendered from
HTML documents or Web pages are displayed on the sides of virtual buildings.
[003] In this environment the browser is required to display the textures as a
user navigates
through the virtual city. In a virtual city having a large number of virtual
buildings, the number
of textures that are potentially stored and displayed may be very large, and
each texture may be
large, e.g., 1 Mb or larger. Storing thousands of such high-resolution
textures for display in real
time as a user navigates a virtual three-dimensional environment would require
more main
memory than is presently available in conventional personal computer systems.
While some
personal computers use graphics display cards that have a dedicated display
memory facility, the
memory capacity of such cards is typically too small to store all high-
resolution textures for all
textures that are in view.
[004] While such textures could be stored in mass storage or a cache, loading
the textures
from such storage at display time would cause an unacceptable time delay for
the user because
1

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
such storage performs at a relatively slow rate. Thus, some textures may not
be available in main
memory or display memory when needed due to disk latency. What is needed is a
better way to
manage display of high-resolution textures in an environment in which some
textures appear far
away in a virtual environment such that many details of the textures are not
visible from the
viewpoint of the user when the textures are rendered for that viewpoint.
[005] Further, in this environment certain textures are displayed in the
foreground from the
perspective of the user and other textures are displayed further away. To
provide a realistic
display the system is required to display foreground textures in high
resolution; however, more
distant textures need not have the same resolution. In this environment, it
would be inefficient
and costly in computational resources to store all textures at one high level
of resolution and
render the textures in low resolution when they are displayed in the distance.
A better approach
is needed for dealing with textures that have changing resolution requirements
according to the
position of the textures in the virtual three-dimensional environment.
[0006] Moreover, source content for the textures, such as HTML documents or
Web pages,
may change over time, for example as the owner or operator of an online Web
site that serves
HTML documents or Web pages makes changes to the documents or pages. Although
such
changes could occur at any time during use of the system, it is impractical to
retrieve the source
content whenever the viewpoint of the user changes or whenever there is a need
to render the
textures again.
2

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
SUMMIA,RY OF THE INVENTION
[0007] The present invention includes, in one aspect, a method of managing the
display of a
large number of graphical textures wherein not all the textures are visible at
any one time, the
method comprising the machine-implemented steps of creating and storing one or
more pools of
high-resolution textures in memory; displaying the textures on polygons in a
virtual three-
diinensional environment; wherein one or more of the textures display
informational content and
deliver informational content to a viewer of the three-dimensional
environment, wherein one or
more of these textures can be viewed at a high level of detail, wherein one or
more of the
textures have approximately similar dimensions, and wherein a viewer can
interact with one or
more of the textures; wherein an arrangement of the textures is defined in one
or more sources,
and wherein the informational content associated with the textures may derive
from one or more
remote sources; and wherein the virtual three-dimensional environment
comprises one or more
channels and wherein one or more of the textures displaying informational
content are aligned
along the channels.
[008] According to one feature, the step of displaying the particular texture
comprises
displaying the particular texture on a polygon in a virtual three-dimensional
environment
According to another feature, the majority of such polygons are regular four
sided 'quads'.
[009] According to another feature, one or more caches of textures are created
on a storage
medium. Textures are saved to these caches after being generated from content
downloaded from
a remote source, or are copies of textures downloaded from remote sources.
They may be saved
as they become available, or all together on program exit. Textures are loaded
from cache to be
used for display either on program startup or on demand. According to another
feature the
program can populate the cache for different three-dimensional environments to
the one
3

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
currently displayed. According to yet another feature all of the textures
relevant to the current
virtual three-dimensional environment which are present in a cache are loaded
from the cache
upon entry to that virtual three-dimensional environment. According to still
another feature the
textures relevant to the current virtual three-dimensional environment which
are present in a
cache are loaded on demand from the cache.
[0010] According to another feature a cache of textures can be held in main
memory.
[0011] According to yet another feature the textures can be compressed.
Textures could be
held in compressed form on the storage medium and uncompressed when loaded
into memory.
In another feature textures could be held in compressed form in memory and
uncompressed
before being transferred to the control of the graphics card. In yet another
feature textures can be
held in compressed form on the graphics card and uncompressed as required for
display by the
card.
[0012] According to still another feature the system can perform the steps of
determining
whether an update exists for a particular content element from among one or
more content
elements, wherein each content element is associated with one or more
textures, and if any
updates exists, updating the relevant texture or textures. If a texture is not
available locally then it
could be considered as suitable for updating.
[0013] In yet another feature a source content to texture generation pool can
be created
which permits more than one source content element to be processed
simultaneously. Such a
pool can be used to provide a single update or generation of a texture, or a
continual stream of
updates based on information contained in the content elements.
[0014] According to another feature generation pool entries can be related to
display pool
entries such that some of the display pool entries are reserved for generating
textures. Such
entries can be used by textures with a high texture priority.
4

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0015] Various events may cause a texture to be updated; including but not
limited to:
changes in position of the texture in the three dimensional environment,
changes in associated
content source, changes in mapping to associated texture source, content
sources containing
animation or other dynamic inforxnation, interactions with the user or
characteristics of the user,
such as age or language preference, or changes of the user's position and/or
viewpoint within the
virtual three-dimensional environment.
[0016] In a further feature a texture may be changed based on the status of
updating that
texture, such as indicating a load or generation is pending, in progress, or
has failed.
[0017] Any of the above updates to a texture could result in a texture being
regenerated, or
download from a remote source.
[0018] In yet a further feature, the system can perform the steps of
determining whether to
display a lower resolution texture in place of a high-resolution texture based
on one or more
criteria. One or more low-resolution texture may be allocated for each high-
resolution texture.
Sucli low-resolution textures may be stored on a mass storage system, and/or
downloaded via a
network. The download of low priority textures may be ordered based on a
defined texture
priority, such priority may based on the viewer's location in the virtual
three-dimensional
environment.
[0019] According to another feature each low-resolution texture can be
generated at the same
time as the corresponding high resolution texture. According to a different
feature each low
resolution texture can be downloaded to a client computer system over a
network. In a further
feature one or more larger pools of lower-resolution textures corresponding to
each high
resolution texture are created.
[0020] In another feature the polygons are assigned texture priorities for the
various options
of loading from, saving to cache, generating, processing updates, providing
live updates,

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
downloading source content, downloading complete textures, or any of the other
aspects of
managing the environment. Such priorities can be assigned based on a number of
criteria
including the user's position and viewpoint in the world, whether the texture
is likely to become
visible in the near future, whether the source content has been updated since
the texture was last
generated, or contains information which would cause the texture to be updated
dynamically.
Each operation can have its own set of priorities - it is not necessary for
the priorities relating to
loading from cache to be the same as those for generating, though it is likely
they may be similar.
[0021] In yet another feature, polygons having a higher texture priority are
allocated entries
in the high-resolution texture pool, and some of the remaining polygons are
allocated low-
resolution textures.
[0022] In another feature, the content is downloaded over a network to a
client computer
system, organized and rendered using the client computer system after
downloading. In yet
another feature the content is owned or controlled by more than one entity. In
still another
feature the source content comprises one or more of Internet pages, television
screenshots,
mobile phone pages, game screenshots, images, documents, or video content.
[0023] In another feature the system will perform the step of blocking the
user from altering
the location of textures within the virtual three-dimensional environment by
interacting with the
virtual environment
[0024] In still another feature, when determining if a polygon associated with
a particular
textures needs to be made available; if the step of generating the texture has
completed, the
particular texture is displayed; if the step of generating the texture has not
completed, a second
particular texture is displayed. The second texture could be a low or high
resolution texture, and
could be related to an earlier version of the first texture, or selected from
an existing set of
alternative textures not based on the first texture.
6

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0025] In another feature when determining whether a polygon needs to be made
available,
wherein the polygon is associated with the particular texture; if the texture
is in memory, the
particular texture is displayed; if the texture is not in memory, a process to
obtain that texture
into memory is initiated, and a second particular texture is displayed while
that load is not
complete. In another feature the process of obtaining the texture comprises
loading the texture
from a local storage medium. In yet another feature the process of obtaining
the texture
comprises downloading the texture from a network.
[0026] In another feature, one or more texture pools are dedicated to the
loading and
generating of textures and a separate texture pool is created for dealing with
the display of
textures; when a texture is finished generating it will replace an entry in
the display texture pool
if the generated texture is required for viewing more urgently than one of the
textures already in
the display pool; the entry in the load/generate pool will then be released
for user by other
textures.
BRIEF DESCRIPTION OF THE DRAWINGS
[0027] The present invention is illustrated by way of example, and not by way
of limitation,
in the figures of the accompanying drawings and in which like reference
numerals refer to
similar elements and in which:
[0028] FIG. 1 A is a block diagram that depicts an example system for
displaying graphical
textures.
[0029] FIG. 1B is a block diagram of an example virtual space browsing system
in which an
embodiment may be used.
[0030] FIG. 1 C is a flow diagram providing a high-level overview of a process
for preparing
to displaying textures in a virtual three-dimensional environment.
[0031] FIG. 2 is a flowchart that depicts a process for dynamically updating
textures.
7

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0032] FIG. 3 is a flowchart that depicts a process for handling dynamically
updated quads.
[0033] FIG. 4 is a flowchart that depicts a process for handling dynamically
updated
textures.
[0034] FIG. 5 is a flowchart that depicts a process for loading or saving
textures.
[0036] FIG. 6 is a block diagram that illustrates a computer system upon which
an
embodiment of the invention may be implemented.
DETAII.,ED DESCRIPTION OF THE PREFERRED EMBODIMENT
[0037] A method and apparatus for displaying graphical textures is described.
In the
following description, for the purposes of explanation, numerous specific
details are set forth in
order to provide a thorough understanding of the present invention. It will be
apparent, however,
to one skilled in the art that the present invention may be practiced without
these specific details.
In other instances, well-known structures and devices are shown in block
diagram form in order
to avoid unnecessarily obscuring the present invention.
[0038] Embodiments are described herein according to the following outline:
Structural Overview
Functional Overview
Hardware Overview
Extensions and Alternatives
STRUCTURAL OVERVIEW
[0039] FIG. 1 A is a block diagram that depicts an example system for
displaying graphical
textures. The term "texture" refers to a digital bitmap image that has been
previously rendered
from source content, such as an HTML document or Web page or other interactive
content. A
display and generation module 110 is communicatively coupled to a loading and
saving module
120. The display and generation module 110 and loading and saving module 120
each comprise
8

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
one or more computer programs, instructions, or other software elements that
cooperate to
perform the functions described herein. In general, display and generation
module 110 is
responsible for displaying and generating textures in a computer display.
Loading and saving
module 120 is responsible for loading and saving textures to and from memory,
respectively, as
needed according to the methods described herein.
[0040] FIG. 1B is a block diagram of an exainple virtual space browsing system
in which an
embodiment may be used. A computer 1001A hosts a three-dimensional virtual
space browser
1001B and an operating system 518. The computer 1001A also includes a main
memory 1007A
and a display card 1008A having display memory 1008B. Display card 1008A may
use some of
the main memory 1 007A for storage of display information. Computer 1001A is
communicatively coupled directly or indirectly through one or more networks
510 to an
application service provider 505 and one or more content service providers 502
that host stored
content 506. In an embodiment, application service provider 505 comprises a
city server of the
type described in Gettman et al. Computer 1001A contains or can access a
source content disk
cache 1021 and secondary page cache 1020. Computer 1001 A displays textures
and other
graphic images or subject matter on a display 1009. In one embodiment,
computer 1001A
comprises a personal computer based on the PCI bus, a workstation, a PDA, a TV
set-top box, a
mobile phone, etc.
[0041] Three-dimensional virtual space browser 1001B comprises initialization
logic 1002,
virtual space display logic 1004, a caclie-input/output (I/0) thread 1006,
window generation
thread 1022, and control/rendering thread 1012. Threads 1006, 1022, 1012 are
spawned by
virtual space display logic 1004 in cooperation with operating system 518 to
perform the
functions described herein.
9

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0042] In general, initialization logic 1002 interrogates display card 1008A,
determines what
graphic display functions are provided by the display card, and turns such
functions on or off,
including providing parameter values as needed, and adjusts its usage of the
card based on the
available capabilities and resources. The foregoing capability of
initialization logic 1002 is
provided because various brands of graphics cards offer different types of
display functions,
thereby enabling three-dimensional virtual space browser 1001B to inter-
operate with many
different kinds of graphics cards. For example, display card 1008A may provide
an anti-aliasing
function for improving the appearance of graphical images that it displays.
Initialization logic
1002 can detect the presence of an anti-aliasing function in display card
1008A and provide
settings to enable the card to properly configure the function.
[0043] Further, in an einbodiment, virtual space display logic 1004 interacts
with display
memory 1008B to display a relatively sinall number of high-resolution textures
and a relatively
large number of low-resolution textures in the display memory. In this manner,
display memory
1008B is continually updated to store high-resolution textures that are
associated with virtual
locations that are near a particular user viewpoint within a virtual three-
dimensional
environment, which is a relatively small number of high-resolution textures,
as well as all
textures that appear in the distance with respect to the user viewpoint, which
is a larger number
of low-resolution textures. Techniques for maintaining the correct number of
textures in display
memory 1008B are described further herein.
[0044] In an embodiment, content 506 of a content service provider 502
comprises one or
more HTML documents or Web pages. Computer 1001A can obtain an updated copy of
content
506 at any time by communicating with content service provider 502 through
network 510.
Further, content 506 may be locally cached at computer 1001A using source
content disk caclie
1021. For example, source content disk cache 1021 can store recently used
source content, such

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
as HTML documents or Web pages, or source content used to generate textures
which are within
a current field of view with respect to the user's then-current viewpoint of
the virtual three-
dimensional environment, or that are likely to be viewed next by the user as
indicated by the
user's location within the virtual three-dimensional environment.
[0045] Cache-1/O thread 1006 is responsible for loading textures and paging
textures to the
texture cache 1020. The cache-I/O thread 1006 is also responsible for saving
updated textures
generated from source content 506 to the texture cache 1020. Texture
generation thread 1022 is
responsible for retrieving content 506 from a content service provider 502 and
generating a
texture based on the content, utilizing source content disk cache 1021 as
appropriate. Control &
rendering thread 1012 is responsible for overall control of elements of the
system and for
rendering textures to the display card 1008A and its display memory 1008B in
accordance with
capabilities of the display card.
[0046] FIG. 1 C is a flow diagram providing a high-level overview of a process
for preparing
to display textures in a virtual three-dimensional environment. In step 130, a
first texture pool
and a second texture pool are created and stored in memory. In one approach,
each texture is
defined and stored in two versions derived from the same source content and
coinprising a high-
resolution texture and a low-resolution texture. Either available main memory
or display memory
stores a relatively small pool of a few high-resolution textures and a
relatively larger pool of
lower-resolution textures. There are no particular limits on the size of each
pool. The small pool
primarily contains textures that are close to the current or prospective
viewpoint of a user in a
virtual three-dimensional environment. The larger pool primarily contains
textures that are
metaphorically in the distance with respect to the user viewpoint. In an
alternative embodiment,
the large texture pool could be split into a pool for loading and generating
textures and a separate
pool for displaying textures.
11

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0047] In one embodiment, a low-resolution version of all possible textures is
stored in local
mass storage associated with a display client, such as disk storage for
computer 1001 A. Content
service provider 502 or application service provider 505 can periodically
generate low-resolution
textures for all display locations of a virtual environment (e.g., display
windows in a virtual city)
and provide the low-resolution textures to the three-dimensional virtual space
browser 1001B at
one time. For example, browser 1001B can download and store all low-resolution
textures at
start-up or initialization time, or as part of an installation process. As a
result, the browser 1001B
only needs to generate high-resolution textures for display locations that are
close to a viewpoint
of the user, and for distant windows for which source content has changed
since the low-
resolution textures were received from the content service provider. When the
browser generates
a high-resolution texture it also generates an updated low-resolution texture.
[0048] In one variant of this approach, if texture generation is required for
any of the
textures, then a certain number of high-resolution texture pool entries may be
reserved for
textures that are undergoing active generation. Since there are a limited
number of entries in the
high-resolution texture pool, entries are assigned to objects that have high
texture priority values.
[0049] In step 136, a virtual three-dimensional environment is created. Each
quad in the
virtual three-dimensional environinent is provided with a quad identifier.
Each texture has a
texture identifier. A texture identifier is assigned to each quad.
[0050] In step 138, a texture priority value is determined and assigned to
each quad. The
texture priority value indicates the current priority order in which textures
are displayed in the
virtual environment. In one embodiment, the texture priority value is based
upon a plurality of
factors such as whether a quad is in view, whether a user has chosen the quad
as a destination,
how far the quad is from the viewer, and an angle of the quad with respect to
the viewer. Each
texture priority value is periodically re-calculated based on the viewer's
then-current position
12

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
and viewing angle as well as user interactions. Further, entries in the
texture pool are re-allocated
to provide optimal usage. In particular, entries in the texture pool for
textures that have become
too far away from the viewer's virtual viewpoint are discarded. Textures that
are based on
changed source content may be re-generated from the source content.
[0051] In step 134, a state value is assigned to each texture in the high-
resolution texture
pool. The use of state values is described further in other sections herein.
[0052] In the foregoing approach, as display locations come into view from the
viewpoint of
a user, the browser 1001B retrieves high-resolution textures for visible
display locations from
texture cache storage and displays them. If source content for such textures
has changed since the
last display time, then the high-resolution textures may be re-generated and
displayed. The re-
generation process is expected to be far slower than loading and displaying
high-resolution
textures from storage and potentially uses up memory that instead could be
used to display
additional high-resolution textures within the virtual environment. Therefore,
in an alternative
approach, generation of all high-resolution textures may be done by a server
and browser 1001B
may download each high-resolution texture over a network connection to the
server as each
texture comes into view.
[0053] Further, in one approach, if the high-resolution texture pool entry
associated with a
quad does not have a high-resolution texture loaded at the time that display
is needed, but the
corresponding high-resolution texture is available on disk, then a low-
resolution texture is used
and displayed and the high-resolution texture is scheduled for loading.
[0054] In an embodiment, low-resolution textures are assigned to the low-
resolution texture
pool as follows. All quads in view from the user's viewpoint, or within a
certain distance thereof,
for which no high-resolution texture is loaded, are provided with entries in
the low-resolution
13

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
texture pool. Any low-resolution texture that is assigned an entry in the low-
resolution texture
pool but that is not present in memory is scheduled for loading.
[0055] One embodiment also uses standard techniques in which each texture
contains
multiple image resolutions or 'mipmaps' to improve the display performance and
to provide a
better quality display during movement of the viewer's virtual position.
[0056] Thus, the approaches herein use multiple versions of textures having
varying
resolution, in contrast to prior approaches in which the level of detail of an
image is changed by
varying the number of virtual polygons on models, or having multiple image
resolutions within
each texture object
[0057] In one embodiment, main memory 1007A comprises a texture bank list
1007B. The
texture bank list 1007B is a data structure that identifies or references all
available high-
resolution textures that are then-currently in use, set for loading, or
generating. In an
embodiment, the following three data structures are used to determine what
textures should be in
the texture bank and to coordinate between a main thread as described below
and a worker thread
for loading and saving as described below. In an alternative embodiment, there
may be two pools
- a texture bank for loading and generating textures and a material bank used
for displaying
textures.
[0058] First, a LiveQuadGeneratePriorityList structure stores a list of quads
that are suitable
for being made live, ordered by priority. A live quad is one which is in view
in the world and
whose texture is beiizg repeatedly updated based on information contained in
the source content.
Second, a QuadGeneratePriorityList stores a list of quads without valid or
with out-of-date
textures that are close enough to warrant generating, ordered by priority.
Third, a
QuadDisplayPriorityList stores a list of quads with valid textures and
suitable for displaying. In
this context, "suitable for displaying" means the quads are close enough to
the viewer's
14

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
viewpoint to be seen by the viewer. The list of quads is ordered by priority,
and does not contain
any quad without a valid texture in memory or on disk. A quad with an out-of-
date texture can be
on both the QuadGeneratePriorityList and the QuadDisplayPriorityList.
FUNCTIONAL OVERVIEW
DISPLAYING GRAPHICAL TEXTURES-MAIN THREAD
[0059] FIG. 2 is a flowchart that depicts a process for handling updates to
textures. FIG. 3 is a
flowchart that depicts a process for handling dynamically updated quads. FIG.
4 is a flowchart
that depicts a process for handling dynamically updated textures. FIG. 5 is a
flowchart that
depicts a process for loading or saving textures. Various embodiments of FIG.
2, FIG. 3, FIG. 4,
and FIG. 5 provide techniques for displaying graphical textures that may be
rapidly updated
based on changes in external content associated with the textures and that may
be rapidly
displayed as a user viewpoint navigates within a virtual three-dimensional
environment or
interacts with a virtual space browser. Although each of FIG. 2, FIG. 3, FIG.
4, and FIG. 5
depicts a certain flow of events, embodiments of the invention are not limited
to these steps or
this flow. Additional steps could be performed, steps could be left out, and
the steps could be
performed in parallel or in a different order.
[0060] In an embodiment, the processes of FIG. 2, FIG. 3, and FIG. 4 are
iinplemented as a
main processing thread as part of virtual display logic 1004 (FIG. 1).
[0061] Referring first to FIG. 2, a process for handling updates to textures
comprises
determining if a specified or pre-defined time period has elapsed, in step
202. The specified time
period is selected to provide a reasonable update frequency for a display of
textures. For
example, in one embodiment the specified time period is 0.1 seconds so that
the display is
updated ten (10) times per second.

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0062] If so, then in step 204 the process determines whether one or more
texture updates are
available. In this context, an update refers to a new texture, or a source
content determined
change in the texture. For example, in the context of FIG. 1 B, computer 1001
A will have
requested content service provider 502 to serve a current copy of content 506,
and window
generator thread 1022 will process the source content and provide an updated
texture for control
and render thread 1012. If none of the quads to which the texture applies are
'live', then step 204
will evaluate to true once at the end of the processing of the source content,
and control will pass
to step 206 which will update the texture in the world. If one or more of the
quads to which the
texture applies are 'live', then step 204 will evaluate to true once at the
end of initial processing
of the source content, then repeat an arbitrary number of times as the source
content determines
that a change to the viewed texture is required. Some source content once
downloaded may
contain all information required to determine when to make updates to the
texture, such as a web
page with an animated image. Other source content may define a process that
subscribes to
events that are published by content service provider 502, in which the events
indicate when an
update to the texture is required, such as a news ticker.
[0063] Thus, the approach herein enables multiple updates to be processed over
a particular
time period for any form of source content that dynamically changes, whether
it contains active
visual content, such as an animated iinage, airline flight arrival or
departure information, or is
merely updated periodically, such as a news story or a recent special offer.
[0064] Updating a texture in block 206 may involve, in one embodiment,
processing
dynamically updated quads. In this context, a "quad" is a four (4)-sided
object that may display a
texture. In one embodiment, a quad is a surface of a virtual building that is
displayed within a
virtual city, so that displaying a texture in a quad gives the appearance of
displaying content of
the texture within a display window of the virtual building.
16

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0065] In certain embodiments, the same texture may be displayed on multiple
quads. Each
texture is provided with a unique identifier and each quad is provided with a
unique identifier. A
quad list data structure maintained by three-dimensional virtual space browser
1001B maps each
quad identifier to a texture identifier that specifies what texture is to be
displayed on the
associated quad. Further, a texture list data structure maps a particular
texture identifier to one or
more quads.
[0066] FIG. 3 is a flowchart that depicts a process for handling dynamically
updated quads.
Referring now to FIG. 3, in step 302 a test is performed to determine if a
specified or pre-defined
time period has elapsed. Step 302 is intended to broadly indicate that the
process of FIG. 3 may
be performed repeatedly according to a timer, schedule, or in response to an
event. In one
embodiment, step 302 is associated with a 1/3 -second timer so that the
process of FIG. 3 is
repeated three (3) times per second.
[0067] If the specified time has elapsed, then in step 304 a quad generation
list is updated.
The quad generation list is a data structure maintained by the three-
dimensional virtual space
browser 1001B that identifies quads that need to have their texture generated
or updated from
source data. The effect of step 304 is to determine whether quads need to be
generated, and if so,
add the quads to the generation list.
[0068] In step 306 a texture bank is consulted and a test is performed to
determine whether
any textures have completed generation. If so, then control passes to step 320
in which the
complete quads which reference that texture are added to a quad display list.
Thus, the complete
quads become available for display later in the process. The texture bank
entry associated with
the completed texture is also updated to indicate the texture needs to be
saved to the texture
cache in step 318. In step 316, the complete quads are removed from the quad
generation list if
the test of step 306 is true.
17

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0069] However, if the test of step 306 is false, or after all complete quads
are processed in
the loop of step 320, 318, 316, then control passes to step 308 in which a
test is performed to
determine if any timeout has occurred for any quad identified in the texture
bank. The purpose of
step 308 is to determine whether a quad was not generated and displayed within
a specified time
period. In that case by policy the process prefers to recover resources that
are used by the
incomplete quad so that a different quad can be processed using the same
resources. If the test of
step 308 is true, then the associated quad is removed from the quad generation
list in step 322.
[0070] Once there are no outstanding timeouts as determined by step 308, then
in step 310,
the quad display list is updated. The quad display list identifies which quads
are most eligible to
be displayed. For example, in one embodiment the quad display list does not
contain non-visible
quads. Thus, changes to the quad display list are primarily driven by the
virtual position of a user
or viewer in the virtual three-dimensional environment.
[0071] In step 312 the texture bank is updated based on the quad display list.
For example, in
one embodiment step 312 involves determining up to five (5) entries in the
texture bank which
refer to quads least appropriate to the current field of view for the user and
replacing them with
entries referring to textures from quads from the top of the quad display list
which are not
currently in the texture bank. The newly assigned texture bank entries are
tagged with a state
value indicating that they need to be loaded from memory or storage.
[0072] In step 314, content sources for textures to be generated or
regenerated from source
content are assigned to entries in the texture bank. The content sources may
be obtained, in one
embodiment, from the quad generation list data structure. Step 314 has the
effect of further
defming what textures should be in the texture bank.
[0073] FIG. 4 is a flowchart that depicts a process for handling dynamically
updated textures.
In step 402, a test is perforined to determine if a predefined time has
elapsed. In one
18

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
embodiment, step 402 implements a timer having a duration of 0.1 seconds so
that the process of
FIG. 4 is repeated 10 times per second. If not, then the process of FIG. 4
terminates at step 416.
[0074] If the timer has elapsed, then in step 406, a test is perforrn.ed to
determine whether any
texture in the texture bank which had previously been marked as load required
has completed
loading and is now marked as loaded into display card memory. If so, then in
step 408 the texture
is used in the virtual three-dimensional environment, and in step 410 the
texture bank entry
associated with that texture is marked as 'visible', which indicates it is
currently being used in
the virtual three-dimensional environment and could be eligible to be replaced
at some point by
another texture if the user's viewpoint changes such that the other texture
would be a more
appropriate use of that texture bank entry.
[0075] After all loaded textures are processed in the loop of step 406, 408,
410, in step 412 a
test is performed to determine if any texture is marked as saved. If so, then
the texture is set to
visible in the texture bank at step 414. Such textures can be removed if they
are too far away
from a viewpoint of=a viewer or user.
LOADING AND SAVING TEXTTJRES-WORKER THREAD
[0076] FIG. 5 is a flowchart that depicts a process for loading or saving
textures. In one
embodiment, the process of FIG. 5 is implemented in a worker thread of virtual
space display
logic 1004 of three-dimensional virtual space browser 1001B. The process of
FIG. 5 may be
applied to load textures into a video display card of a computer such as card
1008 of FIG. 1.
Alternatively the process of FIG. 5 may be used to load textures into a
texture bank in shared
memory that is used for driving a display, or atiy other appropriate storage
location that is linked
to or referenced by a display. The process of FIG. 5 is particularly
appropriate for loading or
saving large, high-resolution textures.
19

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0077] In step 502, a test is performed to determine if any textures are
tagged in the texture
bank with a state value indicating that loading or saving is required. If no
textures are so tagged
in the texture bank, then in step 504 the process of FIG. 5 waits, ceases
operation or "sleeps" for
a specified small time period.
[0078] Otherwise, the loop of steps 506, 508, 510, 512 is performed for each
texture that is
tagged in the texture bank for loading or saving. In step 506, a tagged
texture is selected for
loading or saving. In step 508, the selected texture is tagged in the texture
bank as then-currently
undergoing a loading or saving operation. In step 510, the texture is loaded
or saved from or to
mass storage such as disk, as appropriate. In step 512, the texture is tagged
as having been loaded
or saved.
[0079] By indicating the texture bank entry on which is currently operating
the worker thread
permits the main thread to cancel load-required and save-required states of
other texture bank
entries based on updated quad priorities resulting from changes in the user's
viewpoint while the
worker thread is operating on its current texture bank entry.
[0080] Generally, the approach of FIG. 5 provides a way to selectively load
textures into
memory and display the textures based on an ordered list of what is to be
displayed. For
example, when display card 1008 has a relatively small memory space, the
process of FIG. 5
may be used to load only those textures that are located directly in front of
a virtual location of a
viewer, user or browser within a virtual three-dimensional environment
Alternatively, when
display card 1008 has a large memory space, a larger nuinber of textures may
be tagged in the
texture bank and subsequently displayed with the process of FIG. 5.
[0081] The information for the set of textures to load or save can either be
held directly in
the texture pool, or as a queue of operations. The queue gives the main thread
more control over
the order of actions and also becomes more efficient for larger total sizes of
the texture pool.

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0082] As alternatives to FIG. 5, several other approaches may be used. If the
virtual
environment includes a large number of small textures then ensuring the
optimal set is in
memory as the viewer moves around can be relatively expensive, both in terms
of computational
cost, and in loading a large number of relatively small items from disk.
According to one
approach, the small textures are saved into a single file that is mapped into
memory. In a variant
of this approach, the file is maintained in an open state and each small
texture is read at the
appropriate time by seeking to the appropriate position in the file. This
variant approach only
affects the arrangement of textures on disk, and reduces disk overhead.
[0083] In a second approach, the virtual environment is divided into multiple
sections, for
example, by conceptually overlaying a large grid onto the virtual environment
and grouping all
objects in a single grid square together. The textures in the sections closest
to the viewer are kept
in ineinory. As the viewer moves around, entire sections of textures are
discarded, and new
sections are loaded. This approach significantly reduces the computational
overhead of
calculating which small textures should be in memory.
[0084] In a third approach, the foregoing two alternative approaches are
combined, such that
textures in a single section are stored together in the same file. It is
possible to use a single file
for all sections, or one file per section. A complication of this approach is
that if a texture is used
on more than one object it may be used in multiple sections, requiring it to
be saved more than
once.
[0085] In a fourth altemative approach, textures are held in a compressed
format in main
memory and uncompressed as required. This approach can be combined with the
second
approach above to reduce the computational cost of calculating which textures
are needed, but
the computational cost of uncoinpressing textures may outweigh that gain.
21

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0086] In a fifth approach, multiple textures are packed into a single
hardware texture. For
example, many graphics cards will only process textures for which the image
width and height in
pixels is expressed as a power of two (e.g., 256, 512, 1024, 2048). If the
desired size is not one
of these sizes then some of the memory allocated to the hardware texture is
wasted. To avoid
such waste, memory is allocated in an amount "wider" or "taller" than the
actual texture size, and
such memory stores multiple desired textures. For example, if the desired
texture is 100x64
pixels, the system could allocate hardware textures of 512x64 and pack five
desired textures
horizontally across the hardware texture. At display time the system selects
the desired area from
the hardware texture. In the above case this would reduce the hardware texture
memory usage by
20% as five textures fit into the space that previously would have held four.
This method can be
combined with any of the above approaches.
[0087] In a sixth approach, textures are compressed on disk to save disk space
and reduce the
disk activity time taken to load or save textures. While this approach may
increase the
preparation time for saving a texture, and the post-loading time, this trade-
off is appropriate if
disk activity is a limiting factor and CPU processing power is available. Use
of this approach
may complicate use of the first or third approaches above, as the textures
would differ in size;
usually the same texture would change in size if it is re-generated and
resaved. If the texture
grows in size, then it would no longer fit into the same space in the file. If
the texture becomes
smaller upon re-generation then it would fit, but would waste space.
USE OF STATE VALUES
[0088] The approaches described above indicate that entries in the texture
bank may be
tagged with state values that enable threads to determine how to process the
texture banks. In one
embodiment, the valid state values include Available, Visible, Last Visible,
Generating, Loading,
and Saving. A state value of Available indicates that no valid texture is
associated with the
22

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
texture bank entry. A state value of Visible means that the associated texture
bank entry has a
texture loaded in memory and the associated quad in the virtual environment
has a high texture
priority value. A state value of Last Visible means that the texture was
visible the last time the
process checked, but the associated quad no longer has a high texture
priority.
[0089] A state value of Generating means that texture content is being
generated for the
texture bank entry. A state value of Loading means that a texture has been
assigned to a quad and
a high-resolution texture exists in a storage location such as disk or network
storage, and has
been scheduled for loading from the storage location. While an entry has a
state value of
Loading, the associated quad uses a low-resolution texture in the virtual
three-dimensional
environment.
[0090] A state value of Saving means that generation has completed for the
texture and is in
the process of being saved. The texture can be displayed if the associated
quad is in view in the
virtual three-dimensional environment during the saving process. Once saved,
the pool entry
changes to Visible or Available depending on the quad texture priority.
[0091] In one embodiment, three loading states and three saving states are
used to manage
tasks between the main thread and worker thread described herein:
1. Action (load or save) required (set by main thread);
2. Action (load or save) in progress (set by worker thread);
3. Action (load or save) complete (set by worker thread).
The main thread may tag multiple entries in the texture bank for loading or
saving. If the texture
priorities change, then the main thread can cancel any tags that have not yet
been acted upon or
that are currently in progress in the worker thread. An action currently in
progress cannot be
cancelled.
23

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0092] When several outstanding load and save operations exist, the worker
thread may
balance operations so that all load operations are perforined even when a
series of save
operations need to be performed, or when the converse occurs. If load
operations are always
given priority, then save operations will never occur when the viewer is
moving fast enough to
ensure that at least one load is always outstanding. This will result in the
process of generating
textures stalling until the viewer stops navigating in the virtual
environment. This will maximize
the number of large textures in view at any time, but will increase the
probability of the viewer
moving into a section of the environment where large textures have not yet
been generated.
[0093] Alternatively, if save operations are always given priority then the
generation speed is
maximized, resulting in additional disk traffic from the generation processes
and further reducing
the disk bandwidth available to loading. This will minimize the chance of the
viewer moving into
an area without large textures, but reduce the number of large textures in
view while moving.
[0094] In one approach, if any load operations are outstanding, then at least
a certain number
of the load operations are required to be perfonned between each save
operation. As a result, this
limits the maximum number of consecutive save operations, so there is no
blocking of load
operations for long enough to permit the viewer to move quite close to an
object with an
outstanding load operations.
GENERATING TEXTLTRES
[0095] Generating textures may occur with two approaches. First, a texture may
be re-
generated because the texture is missing or out of date with respect to
associated source content.
Second, a texture may be re-generated because the quad displaying the texture
may be very close
in view and may have been tagged as a live quad, so that the texture displayed
on the quad can
be constantly updated based on information contained in the source content.
The latter approach
enables a quad to display animation, for example.
24

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[0096] In either approach, a change in source content drives re-generating a
texture. For
example, source content such as could be displayed in a conventional Web
browser can be
rendered to a virtual memory window, and updates to this virtual memory window
can be
reproduced in the textures displayed onto a quad. An update may comprise a
change in state of a
Web page, such as an animated image. Three-dimensional virtual display browser
1001B may
incorporate software elements that implement a conventional Web browser such
as Mozilla for
the purpose of loading Web pages comprising source content for textures,
interpreting the HTML
source code of the Web pages, and determining what texture updates are
generated by such
interpretation.
[0097] In one embodiment, updates that are generated as a Web page loads can
be deferred
until the page load is complete. The details of each update requested by the
Web page, such as
the area affected, are passed to the three-dimensional virtual space browser
1001B. The three-
dimensional virtual space browser 1001B maintains one bitmap in memory per
generation
source, and reads out the affected area into the appropriate bitmap in memory.
Each time the
bitmap changes as determined by the conventional browser, the high-resolution
texture is re-
generated. If the generation source becomes inactive because the associated
page load is
complete or because the generation source is taken out of a live state, a low-
resolution version of
the texture is generated, and the bitmap data is saved to mass storage.
[0098] Dynamic content generation may be performed for a large texture pool
using two
approaches. In a first approach, each generating source always has an entry in
the high-resolution
texture pool. Until the generation is complete, the entry will show any
previous version of the
generated conteilt. If there is no previous content the texture pool entry is
effectively unused in
the virtual three-dimensional environment until the generation is complete. In
a second approach,
generating sources do not automatically receive an entry in the high-
resolution texture pool. This

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
means a given texture can be both in the high-resolution texture pool (as the
object is close and
in view), and in a generation source (content is out of date), but there is no
guarantee this will
occur. A generation source that has an entry in the high-resolution texture
pool is processed in
the same fashion as the first approach above. Once a generation source that
does not have an
entry in the high-resolution texture pool has finished generating, the
generated texture becomes
eligible for being copied into the next available entry in the pool.
APPLICATION NOTES
[0099] The present approaches are particularly useful for display of textures
in a virtual
three-dimensional environment in which a large number of large textures are
used. For example,
a virtual three-dimensional environment may comprise a series of channels such
as virtual streets
in a virtual city, or virtual aisles in a virtual store. The textures and
their arrangement are defined
externally to the present system based on metadata or a markup language
description.
[00100] The approaches herein are useful for an environment in which textures
provide
informational content, as opposed to other approaches that are directed toward
display of textures
for aesthetic purposes, for example, in the background environment of a video
game, or as part
of characters of a game. The approaches herein may be used with textures that
provide user
interaction in the nature of a hyperlinked document. In the present approach,
infonnation-bearing
textures are used to form or define a virtual three-dimensional environment
rather than merely
appearing in the environment.
[00101] The approaches herein are also useful when a large number of textures
are rendered
on flat virtual surfaces or polygons. Source content for the textures may come
from remote
sources or local sources. Source content for the textures may be owned or
controlled by large
groups of third parties. Source content may comprise internet pages,
television screenshots,
mobile phone pages, game screenshots, images, documents, or video content,
etc. Textures may
26

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
be dynamic and changing based on extemal content A reinote source can re-
define which
textures are in use and where they are located in the environment, during a
user session. Multiple
animated textures may be provided.
[00102] In one embodiment, users cannot modify the content or location of
textures within the
virtual environment by interacting with the environment.
HARDWARE OVERVIEW
[00103] FIG. 6 is a block diagram that illustrates a computer system 600 upon
which an
embodiment of the invention may be implemented. Computer system 600 includes a
bus 602 or
other communication mechanism for communicating information, and a processor
604 coupled
with bus 602 for processing information. Computer system 600 also includes a
main memory
606, such as a random access memory (RAM) or other dynamic storage device,
coupled to bus
602 for storing information and instructions to be executed by processor 604.
Main memory 606
also may be used for storing temporary variables or other intermediate
information during
execution of instructions to be executed by processor 604. Computer system 600
further
includes a read only memory (ROM) 608 or other static storage device coupled
to bus 602 for
storing static information and instructions for processor 604. A storage
device 610, such as a
magnetic disk or optical disk, is provided and coupled to bus 602 for storing
information and
instructions.
[00104] Computer system 600 may be coupled via bus 602 to a display 612, such
as a cathode
ray tube (CRT), for displaying information to a computer user. A display card
611 A having
display memory 611B may be coupled to bus 602 for the purpose of driving
display 612. An
input device 614, including alphanumeric and other keys, is coupled to bus 602
for
communicating information and command selections to processor 604. Another
type of user
input device is cursor control 616, such as a mouse, a trackball, or cursor
direction lceys for
27

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
communicating direction information and command selections to processor 604
and for
controlling cursor movement on display 612. This input device typically has
two degrees of
freedom in two axes, a first axis (e.g., x) and a second axis (e.g., y), that
allows the device to
specify positions in a plane.
[00105] The invention is related to the use of computer system 600 for
implementing the
techniques described herein. According to one embodiment of the invention,
those techniques
are performed by computer system 600 in response to processor 604 executing
one or more
sequences of one or more instructions contained in main memory 606. Such
instructions may be
read into main memory 606 from another machine-readable medium, such as
storage device 610.
Execution of the sequences of instructions contained in main memory 606 causes
processor 604
to perform the process steps described herein. In alternative embodiments,
hard-wired circuitry
may be used in place of or in combination with software instructions to
implement the invention.
Thus, embodiments of the invention are not limited to any specific combination
of hardware
circuitry and software.
[00106] The term "machine-readable medium" as used herein refers to any medium
that
participates in providing data that causes a machine to operation in a
specific fashion. In an
embodiment implemented using computer system 600, various machine-readable
media are
involved, for example, in providing instructions to processor 604 for
execution. Such a medium
may take many forms, including but not limited to, non-volatile media,
volatile media, and
transmission media. Non-volatile media includes, for example, optical or
magnetic disks, such
as storage device 610. Volatile media includes dynamic memory, such as main
memory 606.
Transmission media includes coaxial cables, copper wire and fiber optics,
including the wires
that comprise bus 602. Transmission media can also take the form of acoustic
or light waves,
such as those generated during radio-wave and infra-red data communications.
28

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
[00107] Common forms of machine-readable media include, for example, a floppy
disk, a
flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-
ROM, any other
optical medium, punch cards, paper tape, any other physical medium with
pattems of holes, a
RAM, a PROM, and EPROM, a FLASH-EPROM, any other memory chip or cartridge, a
carrier
wave as described hereinafter, or any other medium from which a computer can
read.
[00108] Various forms of machine-readable media may be involved in carrying
one or more
sequences of one or more instructions to processor 604 for execution. For
example, the
instructions may initially be carried on a magnetic disk of a remote computer.
The remote
computer can load the instructions into its dynamic memory and send the
instructions over a
telephone line using a modem. A modem local to computer system 600 can receive
the data on
the telephone line and use an infra-red transmitter to convert the data to an
infra-red signal. An
infra-red detector can receive the data carried in the infra-red signal and
appropriate circuitry can
place the data on bus 602. Bus 602 carries the data to main memory 606, from
which processor
604 retrieves and executes the instructions. The instructions received by main
memory 606 may
optionally be stored on storage device 610 either before or after execution by
processor 604.
[00109] Computer system 600 also includes a communication interface 618
coupled to bus
602. Communication interface 618 provides a two-way data communication
coupling to a
network link 620 that is connected to a local network 622. For example,
communication
interface 618 may be an integrated services digital network (ISDN) card or a
modem to provide a
data communication connection to a corresponding type of telephone line. As
another example,
communication interface 618 may be a local area network (LAN) card to provide
a data
communication connection to a compatible LAN. Wireless links may also be
implemented. In
any such implementation, communication interface 618 sends and receives
electrical,
29

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
electromagnetic or optical signals that carry digital data streams
representing various types of
information.
[00110] Network link 620 typically provides data communication through one or
more
networks to other data devices. For example, network link 620 may provide a
connection
through local network 622 to a host computer 624 or to data equipment operated
by an Internet
Service Provider (ISP) 626. ISP 626 in turn provides data communication
services through the
world wide packet data coinmunication network now commonly referred to as the
"Internet"
628. Local network 622 and Internet 628 both use electrical, electromagnetic
or optical signals
that carry digital data streams. The signals through the various networks and
the signals on
network link 620 and through communication interface 618, which carry the
digital data to and
from computer system 600, are exemplary forms of carrier waves transporting
the information.
[00111] Computer system 600 can send messages and receive data, including
program code,
through the network(s), network link 620 and cominunication interface 618. In
the Internet
example, a server 630 might transmit a requested code for an application
program through
Internet 628, ISP 626, local network 622 and communication interface 618.
[00112] The received code inay be executed by processor 604 as it is received,
and/or stored
in storage device 610, or other non-volatile storage for later execution. In
this manner, computer
system 600 may obtain application code in the form of a carrier wave.
EXTENSIONS AND ALTERNATIVES
[00113] In the foregoing specification, the invention has been described with
reference to
specific embodiments thereof. It will, however, be evident that various
modifications and
changes may be made thereto. For example, in various embodiments, multiple
sizes of textures
may be used in combination with the approaches described above. Compressed
textures may be
used for either the high-resolution or low-resolution textures described
herein so that

CA 02567631 2006-11-21
WO 2005/122096 PCT/GB2004/003199
decompression is performed just prior to display at the display card.
Aggressive lossy
compression may be used to reduce the storage size of textures. An in-memory
cache may be
provided. A plurality of different smaller textures may be combined and stored
as a unit to
reduce overall storage size. Thus, in one example, textures for adjacent
windows of a virtual
three-dimensional environment can be amalgamated and rendered as a single
texture. Non-
texture information or vector details may be stored in association with a
texture for use to
generate approximations of textures. The specification and drawings are,
accordingly, to be
regarded in an illustrative rather than a restrictive sense.
31

Dessin représentatif
Une figure unique qui représente un dessin illustrant l'invention.
États administratifs

2024-08-01 : Dans le cadre de la transition vers les Brevets de nouvelle génération (BNG), la base de données sur les brevets canadiens (BDBC) contient désormais un Historique d'événement plus détaillé, qui reproduit le Journal des événements de notre nouvelle solution interne.

Veuillez noter que les événements débutant par « Inactive : » se réfèrent à des événements qui ne sont plus utilisés dans notre nouvelle solution interne.

Pour une meilleure compréhension de l'état de la demande ou brevet qui figure sur cette page, la rubrique Mise en garde , et les descriptions de Brevet , Historique d'événement , Taxes périodiques et Historique des paiements devraient être consultées.

Historique d'événement

Description Date
Exigences relatives à la révocation de la nomination d'un agent - jugée conforme 2021-12-30
Exigences relatives à la nomination d'un agent - jugée conforme 2021-12-30
Inactive : CIB en 1re position 2014-09-16
Inactive : CIB attribuée 2014-09-16
Inactive : CIB expirée 2011-01-01
Inactive : CIB enlevée 2010-12-31
Demande non rétablie avant l'échéance 2010-07-23
Le délai pour l'annulation est expiré 2010-07-23
Inactive : Abandon.-RE+surtaxe impayées-Corr envoyée 2009-07-23
Réputée abandonnée - omission de répondre à un avis sur les taxes pour le maintien en état 2009-07-23
Modification reçue - modification volontaire 2007-10-19
Modification reçue - modification volontaire 2007-07-16
Lettre envoyée 2007-05-22
Lettre envoyée 2007-05-22
Inactive : Transfert individuel 2007-04-16
Inactive : Lettre de courtoisie - Preuve 2007-02-06
Inactive : Page couverture publiée 2007-02-01
Inactive : Notice - Entrée phase nat. - Pas de RE 2007-01-29
Demande reçue - PCT 2006-12-14
Exigences pour l'entrée dans la phase nationale - jugée conforme 2006-11-21
Demande publiée (accessible au public) 2005-12-22

Historique d'abandonnement

Date d'abandonnement Raison Date de rétablissement
2009-07-23

Taxes périodiques

Le dernier paiement a été reçu le 2008-07-23

Avis : Si le paiement en totalité n'a pas été reçu au plus tard à la date indiquée, une taxe supplémentaire peut être imposée, soit une des taxes suivantes :

  • taxe de rétablissement ;
  • taxe pour paiement en souffrance ; ou
  • taxe additionnelle pour le renversement d'une péremption réputée.

Les taxes sur les brevets sont ajustées au 1er janvier de chaque année. Les montants ci-dessus sont les montants actuels s'ils sont reçus au plus tard le 31 décembre de l'année en cours.
Veuillez vous référer à la page web des taxes sur les brevets de l'OPIC pour voir tous les montants actuels des taxes.

Historique des taxes

Type de taxes Anniversaire Échéance Date payée
Taxe nationale de base - générale 2006-11-21
TM (demande, 2e anniv.) - générale 02 2006-07-24 2006-11-21
Enregistrement d'un document 2007-04-16
TM (demande, 3e anniv.) - générale 03 2007-07-23 2007-06-20
TM (demande, 4e anniv.) - générale 04 2008-07-23 2008-07-23
Titulaires au dossier

Les titulaires actuels et antérieures au dossier sont affichés en ordre alphabétique.

Titulaires actuels au dossier
THREE-B INTERNATIONAL LIMITED
Titulaires antérieures au dossier
DAVID C. BROWNLEE
DAVID GETTMAN
LESLIE PETERS
NICOLE MORRIS
Les propriétaires antérieurs qui ne figurent pas dans la liste des « Propriétaires au dossier » apparaîtront dans d'autres documents au dossier.
Documents

Pour visionner les fichiers sélectionnés, entrer le code reCAPTCHA :



Pour visualiser une image, cliquer sur un lien dans la colonne description du document (Temporairement non-disponible). Pour télécharger l'image (les images), cliquer l'une ou plusieurs cases à cocher dans la première colonne et ensuite cliquer sur le bouton "Télécharger sélection en format PDF (archive Zip)" ou le bouton "Télécharger sélection (en un fichier PDF fusionné)".

Liste des documents de brevet publiés et non publiés sur la BDBC .

Si vous avez des difficultés à accéder au contenu, veuillez communiquer avec le Centre de services à la clientèle au 1-866-997-1936, ou envoyer un courriel au Centre de service à la clientèle de l'OPIC.

({010=Tous les documents, 020=Au moment du dépôt, 030=Au moment de la mise à la disponibilité du public, 040=À la délivrance, 050=Examen, 060=Correspondance reçue, 070=Divers, 080=Correspondance envoyée, 090=Paiement})


Description du
Document 
Date
(aaaa-mm-jj) 
Nombre de pages   Taille de l'image (Ko) 
Abrégé 2006-11-20 2 75
Revendications 2006-11-20 11 424
Dessins 2006-11-20 7 109
Description 2006-11-20 31 1 486
Dessin représentatif 2007-01-30 1 11
Avis d'entree dans la phase nationale 2007-01-28 1 205
Courtoisie - Certificat d'enregistrement (document(s) connexe(s)) 2007-05-21 1 107
Courtoisie - Certificat d'enregistrement (document(s) connexe(s)) 2007-05-21 1 107
Rappel - requête d'examen 2009-03-23 1 122
Courtoisie - Lettre d'abandon (taxe de maintien en état) 2009-09-16 1 172
Courtoisie - Lettre d'abandon (requête d'examen) 2009-10-28 1 164
PCT 2006-11-20 3 112
Correspondance 2007-01-28 1 27
Taxes 2007-06-19 1 31
Taxes 2008-07-22 1 30