The World Wide Web has enabled a vast collection of articles to be accessible to many users via the Internet. Using a web browser, users can view these articles that may contain text, images, videos, and other forms of multimedia. Depending on the type of devices accessing these articles, the rendering of content within the articles can vary. This results in a delay ranging from a few milliseconds (i.e., on a desktop or notebook) to several seconds (i.e., on a mobile device or tablet) before the content associated with the article is rendered. Each time a user scrolls to view additional content associated with the article, the delay is repeated. During this delay, the user may see the article or content rendered progressively, which often causes the article or content to appear broken until it is fully loaded or the user may not see the article or content rendered at all until the user stops scrolling. In some instances, the memory required to render certain articles or content within the articles exceeds the available memory of the device which causes the rendering application to crash. These delays and crashes can frustrate users, often leading to a bad user experience or causing the user to give up altogether and seek a similar article or content from another source. Accordingly, to prevent these delays and crashes, content is often provided at different levels of fidelity or in completely different formats to different devices.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
Embodiments of the present invention generally relate to displaying and animating sectioned content that retains fidelity across desktop and mobile devices. More particularly, some embodiments are directed to creating an animation timeline for each article comprising one or more sections. The animation timeline enables the articles to appear as webpages to the user viewing the articles. When a user manipulates the viewport, the animation timeline manages content movement in and out of the viewport. For articles comprising more than one section, an internal timeline that manages content movement inside each section may be created for each section and placed inside the animation timeline. As articles are loaded into memory, they become visible in the viewport and a behavior is attached to each section. This enables memory of the device to be preserved and allows each article to be rendered in full fidelity across any device.
The present invention is described in detail below with reference to the attached drawing figures, wherein:
The subject matter of the present invention is described with specificity herein to meet statutory requirements. However, the description itself is not intended to limit the scope of this patent. Rather, the inventors have contemplated that the claimed subject matter might also be embodied in other ways, to include different steps or combinations of steps similar to the ones described in this document, in conjunction with other present or future technologies. Moreover, although the terms “step” and/or “block” may be used herein to connote different elements of methods employed, the terms should not be interpreted as implying any particular order among or between various steps herein disclosed unless and except when the order of individual steps is explicitly described.
As used herein, a “Slate” refers to a HyperText Markup Language (HTML) document produced by the ADOBE Slate application that serves as a container for one or more articles. When displayed within a browser or WebView, users can navigate between articles by swiping horizontally (left or right) or using the left or right navigation arrow. An “article” is a collection of related content that is suitable for the World Wide Web and can be rendered by a web browser or WebView. A web browser or WebView displays the article via a monitor or a mobile device in an area of the display referred to as a “viewport.” To view the content of an article, users can swipe vertically (e.g., up or down).
The article may comprise HTML, cascading style sheets (CSS), and JavaScript (JS) that are utilized by the web browser to present the page. CSS refers to a style sheet language that is utilized to describe the look and formatting of a document written in a markup language. HTML refers to the standard markup language used to create web pages. A web browser is able to read HTML files and render them as visible or audible web pages. HTML allows images, objects, or scripts to be embedded and can be used to create structured documents and interactive forms. HTML may further refer to CSS to define the look and layout of the page. Multiple HTML pages may share formatting by pointing to the relevant CSS stored in a separate .css file. Elements such as layout, colors, and fonts may be defined by the CSS. JS refers to a computer programming language used by web browsers to allow client-side scripts to interact with the user, control the browser, and alter document content that is displayed.
A “sections article” is a particular type of Slate article that maintains a set of content sections. The main responsibility of the sections article is to sequence and display the sections within the article at the appropriate time. A “section” refers to the logical units that the content within a sections article is split into. Each section is responsible for the display and behavior of the content it contains.
The term “behaviors” refers to patterns associated with a template used to design an article or a section of an article that has a predefined configuration or can perform predefined functions. Users select behaviors when creating a slate document. For example, a table of contents behavior provides a list of one or more articles and enables the article that is selected to be loaded into the viewport. A 50/50 behavior is an article with text on the left side and one or more images on the right side. Behaviors are not attached to an article until the article is loaded into memory. Other behaviors may include zooming in or out, fading in or out, and the like. Each section of an article may have its own behavior. For example, the title section of an article may have a different behavior than the rest of the article.
As discussed previously, users view articles, via a web browser or view port, containing text, images, videos, and other forms of multimedia. Depending on the type of devices accessing these articles, the rendering of content within the articles can vary. Delays ranging from a few milliseconds (i.e., on a desktop or notebook) to several seconds (i.e., on a mobile device or tablet) before the content associated with the article is rendered. Each time a user scrolls to view additional content associated with the article, more delay is experienced. In many instances, the user sees the article or content rendered progressively, which causes the article or content to appear broken until it is fully rendered. In other instances, the user does not see the article or content rendered at all until the user stops scrolling. In extreme cases, the web browser or view port crashes due to lack of memory. These delays and crashes lead to a bad user experience or cause the user to give up altogether and seek a similar article or content from another source. To prevent these delays and crashes, content is often provided at different levels of fidelity or in completely different formats to different devices.
Some embodiments of the present invention are directed to displaying and animating sectioned content that retains fidelity across desktop and mobile devices. As such, upon receiving a request for an article comprising one or more sections, an animation timeline is identified for the article. When a manipulation to the viewport is received, the animation timeline is utilized to manage content movement in and out of the viewport. In this way, the animation timeline (or internal timeline described below) manages when the content inside an article becomes visible and how it becomes visible. The timelines may also trigger behaviors on the content or section itself at specific times within an internal timeline. Each of these behaviors reacts to user initiated events (interactions) and may be created or enabled prior to an article or section becoming visible. In some embodiments, some articles or sections have behavior triggers on the timeline that adjust the visibility or availability of content within an article or section as it moves in and out of the viewport. Each of these behaviors facilitates more efficient management of memory.
In some embodiments (e.g., a sections article), each section in the one or more articles and an internal timeline is identified for each section. In some embodiments, the internal timeline is placed inside the timeline at the time the document is created. As can be appreciated, this provides a user creating the article feedback of how each section appears to a viewer within the context of the overall article timeline (i.e., the “play” time of the article and each section of the article). In some embodiments, the internal timeline is placed inside the animation timeline dynamically when each section starts to enter the viewport. In some embodiments, the section timelines are used in place of an animation timeline (i.e., each section's internal timeline drives the display of each section and each of these are identified rather than identifying an overall article animation timeline).
As the viewport is manipulated the articles that are loaded into memory is changed. For example, a maximum of three articles may be loaded at a time (the current article in the viewport, and the article on either side of the current article). As the viewport is manipulated horizontally, the user switches between articles. Articles that are off-screen are hidden to save memory and improve rendering performance. Also, manipulating the viewport vertically has a similar effect of switching between the sections within the current article.
Referring now to
The animation system 100 generally operates to provide content to a user via a web browser or viewport that retains full fidelity regardless of the device type utilized by the user. To do so, an animation timeline is identified for each article comprising one or more sections. Each article may be a sections article, which enables content to be divided into sections that can be presented in different ways (i.e., with different behaviors attached to each section). As described above, in various embodiments, each section may include its own section timeline which can be placed inside the animation timeline during article creation, placed inside the animation timeline dynamically as each section enters the viewport, or identified and used in place of the animation timeline. Animation is used to display the content within each section which is accomplished through the use of CSS transitions and/or keyframe-animations and JS which adjusts the transforms, opacity, color, and various other properties of the content within the article dynamically as the user scrolls vertically. Although the term scrolling is utilized in connection with the animation system 100, scrolling is actually an illusion to the viewer. Instead, the viewer is actually scrubbing vertically through an article's timeline which can be accomplished by various means, including touch gestures (swiping vertically), mouse wheel, or by using the faux scrollbar (scrubber) that is rendered when an interaction with the article is detected. In this way, the timeline is not tied to the existence of a native scrollbar or native scrolling mechanism. Rather, content is being manually moved via CSS properties which enable updates to the screen while scrolling. At the same time, memory can be managed by turning on or off the display of content at the appropriate times. This enables a given Slate to display and animate with the same fidelity no matter what platform or device it is displayed on. Among other components not shown, the system 100 may include a user device 112, a publication viewer 114, an article database 116, and an animation engine 118.
It should be understood that the system 100 shown in
It should be understood that any number of user devices, publication viewers, animation engines, article databases, and networks may be employed within the system 100 within the scope of the present invention. Each may comprise a single device or multiple devices cooperating in a distributed environment. For instance, the animation engine 118 may be provided via multiple devices arranged in a distributed environment that collectively provide the functionality described herein. In another instance, portions of the animation engine 118 may be provided by the user device 112, the publication viewer 114, or as a web service provided in the cloud. Similarly, portions of the animation engine 118 may be provided by each of the user device 112, the publication viewer 114, and as a web service provided in the cloud. In some embodiments, the publication viewer 114 and the animation engine 118 may be provided by a single device. Additionally, other components not shown may also be included within the network environment.
As shown in
The publication viewer 114 enables vertical scrolling which provides for the navigation of content for an article. However, some mobile browsers do not fire scroll events at the same rate, or even at all, while the user is drag-scrolling. Additionally, many mobile browsers do not fire scroll events while the user is momentum-scrolling (e.g., as the result of a user flicking the content on screen). In current systems, these events are necessary to know how far into the document the user has scrolled or to determine what content should be in the viewport. Moreover, in some of these mobile-based browsers, what is actually scrolled is a cached version (i.e., a bitmap) of the content, so any screen updating that happens while in the midst of a scroll event, does not show up until the user lifts up his finger (after a drag-scroll) or momentum-scrolling has stopped.
To overcome this, the publication viewer 114 utilizes “faux scrolling.” Instead of using libraries such as iScroll, which listen for touch events and use CSS transforms to move a specific element through the viewport, the publication viewer 114 separates out the detection for the gesture (i.e., for drag-scrolling or momentum-scrolling) and the animation engine 118 utilizes an animation timeline to manage and choreograph all content movement on screen. In this way, the animation engine 118 equates a pixel-length with a millisecond in the timeline.
As the user makes a gesture for scrolling, the distance in pixels the gesture traveled can be mapped by the animation engine 118 to the number of milliseconds that should be played in the timeline. Tweens and/or triggers are placed by the animation engine 118 at the appropriate offsets in the timeline to animate elements via CSS transforms (and other properties), or classes may be placed on the elements to trigger CSS transitions/key-frame animations. This enables multiple advantages. First, it frees the publication viewer 114 from being tied to the physical height of the article. In this way, the article is as long as the timeline duration. It also allows the state and movement or animation of any sections or elements within the article, at any given time, to be synchronized without having to constantly measure elements or figure out where they are relative to the viewport during each scroll event. Additionally, the screen can update dynamically even in the midst of momentum-scrolling or drag-scrolling. Finally, the publication viewer 114 is not tied to vertical scrolling between sections of content. Sections can utilize fades, horizontal, and three-dimensional movement.
CSS transforms are utilized, in some embodiments, by the animation engine 118 to take advantage of GPU rendering on mobile devices, which results in smoother animations. However, this speed advantage can be negated if the layout size of the element being transformed is greater than 1024 pixels in any of its dimensions. This results in the element being rendered to be split across several tiles (of max dimension 512 pixels). Since a full rendering pass is done for each tile any time that element is re-rendered, any speed gain is lost.
For an article that has a lot of content sections, avoiding this tile-rendering limit is difficult if the sections are flowed one after the other because the body expands to encompass all of the content it contains. To avoid this situation, the publication viewer 114 limits the height of each section and all of its parent elements, up to and including the body element, so that they never exceed the height of the viewport and never show any content that hangs outside of them. The publication viewer 114 then absolutely positions all sections on top of each other so the body of the article never has a height greater than the viewport. The animation engine 118 then adds the appropriate CSS transforms/tweens to the timeline to move the section off-screen and out of view (just below the fold). Each section is then moved by the animation engine 118 upwards through the viewport, at the appropriate time, giving the illusion of scrolling content that appears as if it was statically laid out.
The publication viewer 114 also can make use of large background images and/or photos. These are normally problematic on mobile devices, especially iOS devices, if they exceed 1024 pixels in any dimension. Transforming and moving images with dimensions larger than 1024 pixels in any dimension causes transform animations to stutter. For this reason, the publication viewer 114 loads images that are a maximum of 1024 pixels in dimension by default. If the publication viewer 114 detects that any sections are larger than this dimension, the publication viewer 114 assumes it is loaded within a desktop browser and attempts to load higher-resolution images that may exceed 1024 pixels in dimension.
In embodiments, the animation engine 118 also manages the content in each section. This includes determining when each element inside the section animates. In general, an element inside the section does not animate unless the section is, at a minimum, partially visible within the viewport. This rule can be enforced by the animation engine 118 because each section includes its own internal timeline. The internal timeline is responsible for animating the content inside the section and is placed in the article timeline at the point in time when the section starts to enter the viewport. This nested section timeline can also be used to bring content into the section viewport at the appropriate time just like the article timeline brings sections into view at the appropriate time further extending the illusion of statically laid out content. Compartmentalizing the animations and tweens/triggers for a given section in its own nested timeline also has the side effect of decreasing the number of timeline objects the article timeline must sort through each timeline frame when it determines what objects should actually execute at that given moment, which results in improved performance.
Use of CSS transforms may result in large amounts of memory being allocated by the browser for caching and fast rendering of the transformed element. On mobile devices with limited memory, this can be problematic and may cause the browser to crash. To avoid crashes, the animation engine 118 places hide/show triggers in the article timeline at the appropriate time (e.g., based on the article, or section, being inside the viewport). This enables articles or sections that are outside of the viewport to release their cached resources. The animation engine 118 accomplishes this by setting CSS properties to release cached resources. Because each section has its own internal timeline, behaviors of individual sections may cause content (i.e., full width/full screen images and photo grids) to be divided into chunks so triggers can be used to hide/show them depending on whether a particular chunk is inside or outside the viewport allowing more memory to be freed for the device.
In some instances, this hiding/showing results in a slight delay as the section's visibility is toggled by the publication viewer 114 from hidden to shown as it enters the viewport during scrolling. This is caused by the browser rebuilding its off-screen buffers for each image that will be rendered. For sections containing single images, this delay is almost unperceivable. But, for sections like photo grids that contain multiple images, the delay may be noticeable. The greater the number of images in the grid, the longer the hiccup. The publication viewer 114 strikes a balance between preserving memory and lessening long delays. For large photo grids, the photo grid section may resort to hiding/showing individual rows (or groups of rows) of the photo grid, as needed, via the internal timeline. So, instead of the user experiencing one long delay, the user may experience smaller, unperceivable, delays as each row comes into view. Or, rather than managing hide/show at the row level, the publication viewer 114 may choose to not hide any of the grid images at all if the size of the images within the article falls within an acceptable memory usage threshold.
In an exemplary embodiment, the publication viewer 114 identifies all of the articles within a Slate document when a browser loads a shared link. The visibility of each article, based on a user interaction, is also managed by the publication viewer. Three articles at a time are visible (i.e., loaded into memory). Initially when the first article is shown (or made the current article) there are only two articles visible since no article precedes the first article. The publication viewer 114 further identifies the type of article so that it can be initialized properly. Each article can have different behaviors associated with them. For example, the sections article behavior includes scrolling/animation to provide the appearance of scrolling between sections of the article. Each article type may include a handler associated with it, in an article handler registry. When it is time to initialize an article, the publication viewer 114 looks up the handler for a given article based on its article type. If there is a handler defined for that type, the publication viewer 114 invokes the handler that is responsible for initializing the article to activate/setup all of its behaviors and prepare the content within it. For the sake of preserving memory and initialization time, the publication viewer 114 delays invoking the initialization handler for a given article until the article is made visible (i.e., either made the current article immediately preceding or following the current article). The other reason this is necessary is because the article behaviors may also require geometric dimensions of the content within the article which may only be available if the article is visible (either current or immediately preceding or following). With respect to the sections article handler, an internal timeline is created to manage when sections come into and out of view, etc. The sections article handler also has some behaviors that are similar to the publication viewer 114. For example, it identifies the sections within the article, and based on the type of the section, an initialization handler is invoked for that section based on handlers registered in a sections registry. These section handlers define the behaviors and animations used within a particular section, and the handlers are also responsible for adding internal section animations/behaviors to the article timeline. However, unlike with the article handle, the section handler initializes all sections of the article at once so the article handler can get a complete picture of all the sections, their internal timelines, etc., that the article handler must manage and synchronize together to perform the expected behaviors. Also, viewport resizing may cause reinitialization to be necessary. For example, if the user rotates the device the article is being viewed on or the user resizes the browser window (i.e., on a desktop), the sections article handler performs a re-initialization of the article because the geometry of the content may have changed, so the timeline and all other animations/behaviors need to be changed accordingly.
With reference now to
As described above, as content 222, 224, 232, 234 is scrolled beyond the viewport 210 and beyond the regions 240, 250 immediately preceding or following the viewport 210, a different portion and/or a particular length in the animation timeline is played, and the section 220, 230, or content 222, 224, 232, 234, may be released from memory. For example, as the user continues to scroll forwards to view section 230 in the viewport 210, section 220 may be released from memory. Additionally, another article or section (not shown) that follows section 230 may be loaded into memory. This memory management enables a mobile device to display the article or sections in full fidelity.
Referring now to
Turning now to
With reference initially to
In
Referring now to
Referring next to
As shown at step 410, a request for a document comprising one or more articles is received. The request causes at least a portion of an article to be loaded into a viewport, such as by publication viewer 114 of
In some embodiments, the article is created by a user and shared as a link. Upon selection, the article appears to other users as an HTML page. The animation timeline defines article behaviors. Each section may have defined behaviors, such as in a sections article. These behaviors include attributes that cause the article or sections within the article to be presented in a particular manner. For example, the behaviors can cause the viewport to present the article as a table of contents or as a 50/50 behavior (text on left side of article, image on right side of article). The behaviors may cause portions of the article to appear as if the portions are zooming in or out or fading in or out. As can be appreciated, many different behaviors can be attached to an article or section of an article by the user creating the article.
In some embodiments, the articles that are loaded into memory is managed, such as by publication viewer 114 of
At step 412, a manipulation to the viewport is received. The manipulation is received via a user interaction with a viewport scroll bar or with the viewport itself (i.e., a vertical swipe). Although
In some embodiments, articles are kept visible off screen (i.e., outside the viewport or underneath an article being presented within the viewport) if there is enough remaining memory to keep the article in memory. If there is not enough memory to keep the article in memory, the article is removed from memory.
In some embodiments, the movement of any sections within an article at any given time is synchronized without having to measure elements or figure out where the elements are relative to the viewport during each scroll event. Use of the animation timeline means the scroll events are tied to the timeline and not any measured distance. In other words, each pixel-length is the equivalent of a millisecond in the timeline. As the user manipulates the viewport via some type of gesture or interaction, sections of an article may be moved through the viewport. However, the distance a particular section moves does not correspond to the distance/height of the article. Instead the distance a particular section moves corresponds to the length of the timeline of the current article. In other words, the distance in pixels the gesture travels is equal to a portion of the timeline (e.g., the number of milliseconds that should be played in the timeline).
Referring now to
As shown at step 510, an animation timeline is identified for an article that comprises one or more sections. At least a portion of the article is rendered via the viewport, at step 512, in full fidelity across any device. In some embodiments, at least a portion of the article that is loaded into memory is visible within the viewport. In some embodiments, each of the sections immediately preceding and immediately following the section of the article that is currently visible within the viewport are also loaded into memory. In some embodiments, cached resources are released for a section as it leaves the viewport. For example, as the user scrubs through an article, sections that are no longer in the viewport (or on either side of the section currently visible in the viewport) are released from memory. This frees resources of the device so that each article can be presented in full fidelity even if the user is utilizing a mobile device.
Each section in the one or more articles is identified, at step 514, and may include behaviors for each section. These behaviors may be defined in an internal timeline that is initialized, at step 516, when the article is loaded into memory. In embodiments, the behaviors comprise various attributes that affect how the content of a section is presented to a user. For example, the behaviors may include zooming in/out, fading in/out, or how the content of a section is laid out.
A manipulation to the viewport is received at step, 518. The manipulation utilizes the animation timeline (which may include one or more internal timelines nested within the animation timeline) to manage section movement in and out of the viewport. In some embodiments, the movement of any content within a section is synchronized at any given time without having to measure elements or figure out where the elements are relative to the viewport during each manipulation of the viewport. Because manipulations are tied to the timeline and not any measured distance, each pixel-length is the equivalent of a millisecond in the timeline. Thus, the distance in pixels a gesture travels is equal to the number of milliseconds that should be played in the timeline. This prevents size of content within a section from being an issue when displaying the section in full fidelity on a mobile device.
In some embodiments, in addition to managing content movement, content visibility is also managed to release resources. For example, in a photograph grid, sections are utilized to show/hide/release resources for photographs in rows of the grid that are no longer visible. Similarly, content visibility can be managed for hiding images in long text sections that have scrolled out of the viewport. In various embodiments, there are three levels of showing/hiding that occurs to release resources: 1) at the article level, articles that are not current or preceding or following the current article are hidden (this is managed by a document level timeline); 2) at the section level, sections that are outside of the viewport are hidden to release all their resources (this is managed by the article timeline); and 3) at the content level, content that is outside of the section viewport may be hidden to release resources (this is managed by the internal section timeline).
Having described embodiments of the present invention, an exemplary operating environment in which embodiments of the present invention may be implemented is described below in order to provide a general context for various aspects of the present invention. Referring initially to
The invention may be described in the general context of computer code or machine-useable instructions, including computer-executable instructions such as program modules, being executed by a computer or other machine, such as a personal data assistant or other handheld device. Generally, program modules including routines, programs, objects, components, data structures, etc., refer to code that perform particular tasks or implement particular abstract data types. The invention may be practiced in a variety of system configurations, including hand-held devices, consumer electronics, general-purpose computers, more specialty computing devices, etc. The invention may also be practiced in distributed computing environments where tasks are performed by remote-processing devices that are linked through a communications network.
With reference to
Computing device 600 typically includes a variety of computer-readable media. Computer-readable media can be any available media that can be accessed by computing device 600 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer-readable media may comprise computer storage media and communication media. Computer storage media includes both volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by computing device 600. Computer storage media does not comprise signals per se. Communication media typically embodies computer-readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of any of the above should also be included within the scope of computer-readable media.
Memory 612 includes computer-storage media in the form of volatile and/or nonvolatile memory. The memory may be removable, non-removable, or a combination thereof. Exemplary hardware devices include solid-state memory, hard drives, optical-disc drives, etc. Computing device 600 includes one or more processors that read data from various entities such as memory 612 or I/O components 620. Presentation component(s) 616 present data indications to a user or other device. Exemplary presentation components include a display device, speaker, printing component, vibrating component, etc.
I/O ports 618 allow computing device 600 to be logically coupled to other devices including I/O components 620, some of which may be built in. Illustrative components include a microphone, joystick, game pad, satellite dish, scanner, printer, wireless device, etc. The I/O components 620 may provide a natural user interface (NUI) that processes air gestures, voice, or other physiological inputs generated by a user. In some instance, inputs may be transmitted to an appropriate network element for further processing. A NUI may implement any combination of speech recognition, touch and stylus recognition, facial recognition, biometric recognition, gesture recognition both on screen and adjacent to the screen, air gestures, head and eye tracking, and touch recognition associated with displays on the computing device 600. The computing device 600 may be equipped with depth cameras, such as, stereoscopic camera systems, infrared camera systems, RGB camera systems, and combinations of these for gesture detection and recognition. Additionally, the computing device 600 may be equipped with accelerometers or gyroscopes that enable detection of motion. The output of the accelerometers or gyroscopes may be provided to the display of the computing device 600 to render immersive augmented reality or virtual reality.
As can be understood, embodiments of the present invention facilitate displaying and animating sectioned content that retains fidelity across desktop and mobile devices. The present invention has been described in relation to particular embodiments, which are intended in all respects to be illustrative rather than restrictive. Alternative embodiments will become apparent to those of ordinary skill in the art to which the present invention pertains without departing from its scope.
From the foregoing, it will be seen that this invention is one well adapted to attain all the ends and objects set forth above, together with other advantages which are obvious and inherent to the system and method. It will be understood that certain features and subcombinations are of utility and may be employed without reference to other features and subcombinations. This is contemplated by and is within the scope of the claims.
Number | Name | Date | Kind |
---|---|---|---|
9141402 | Hewitt | Sep 2015 | B2 |
9361130 | SanGiovanni | Jun 2016 | B2 |
9858969 | Khan | Jan 2018 | B2 |
20040217980 | Radburn | Nov 2004 | A1 |
20050053359 | Jung | Mar 2005 | A1 |
20060010246 | Schulz | Jan 2006 | A1 |
20110202837 | Fong | Aug 2011 | A1 |
20110225547 | Fong | Sep 2011 | A1 |
20120056889 | Carter | Mar 2012 | A1 |
20120137308 | Agarwal | May 2012 | A1 |
20130176316 | Bates | Jul 2013 | A1 |
20130222395 | Blas, Jr. | Aug 2013 | A1 |
20140071074 | Cousins | Mar 2014 | A1 |
20140229818 | Goswami | Aug 2014 | A1 |
20150095839 | Hombert | Apr 2015 | A1 |
20150243257 | Witman | Aug 2015 | A1 |
20160012018 | Do Ba | Jan 2016 | A1 |
20160070434 | Clark | Mar 2016 | A1 |
20160231894 | Ying | Aug 2016 | A1 |
20170017616 | Elings | Jan 2017 | A1 |
20170024098 | Doherty | Jan 2017 | A1 |
20180011580 | Lebowitz | Jan 2018 | A1 |
Number | Date | Country | |
---|---|---|---|
20170132829 A1 | May 2017 | US |