This specification relates to computer programming, and, more particularly, to declarative animation timelines.
Some animations or multimedia presentations may include one or more “actors” (e.g., images) performing various tasks, movements, or transitions on a “stage” (e.g., a screen or display). For example, a relatively simple animation may include a transition that hides or shows an object in a computer window. Meanwhile, a more complex animation may include a set of two or more actors (e.g., images of human characters), each actor having a set of elements (e.g., head, arms, body, legs, etc.) that may be displayed in a coordinated or choreographed manner to give the viewer the impression that the actors are moving (e.g., walking, jumping, etc.) across the screen.
In traditional timeline-based animation applications, in order to create more than one hide or show transition for more than one actor, a designer has traditionally taken one of two approaches. First, the designer may perform the animation completely in software code. Alternatively, the designer may create an animation on a timeline for each transition/actor combination, and then use software code to programmatically jump to a selected place in the timeline in order to execute the appropriate combination.
This specification discloses systems and methods for generating, using, and/or executing declarative timelines in an animation application (e.g., animation design software, website development program, Internet browser, etc.). In some embodiments, the timeline techniques described herein may be used to manipulate and choreograph any technology available via JavaScript, for example, including audio, video, DOM elements (e.g., XML, HTML, SVG, etc), other JavaScript functions and libraries (including those that manage drawing into bitmap elements such as Canvas). These techniques may also be used to manipulate properties on an Internet browser (e.g., viewport scroll position, window title or window dimensions) and/or to trigger communication between frames, windows, or a client and a server.
In some embodiments a method may include generating a serialized, declarative data structure corresponding to a graphical representation of a timeline displayable on a graphical user interface. The method may also include creating an animation of an image along the timeline and adding a declarative command corresponding to the animation into the declarative data structure. The method may further include, in response to a request to render the animation, generating a run-time command corresponding to the declarative command and executing the run-time command.
In some embodiments, the declarative timeline data structure may not include control flow statements and/or Boolean logic. Moreover, the declarative timeline data structure, when processed using the techniques described herein, may create and/or display the animation of an element by modifying a property value of that element over time. For example, when the element is a graphical image, element properties may include its position, opacity, color, etc. In some cases, multiple properties may be animated in parallel so their changes are synchronized. Any type of property (including, for example, HTML properties, CSS properties, and/or SVG attributes) may be animated. A framework may read the serialized declarative representation and produce an internal representation, which may then be executed. A declarative serialized representation, such as described herein, may be highly amenable to modification by automated tools.
In other embodiments, a computer-readable storage medium may have instructions stored thereon that, upon execution by a computer system, cause the computer system to receive a request to execute an animation. In some cases, the animation may include a declarative timeline data structure, and the declarative timeline data structure may include one or more declared objects. The instructions may also cause the computer system to generate one or more run-time objects corresponding to the one or more declared objects, and execute at least one of the one or more run-time objects.
In yet other embodiments, a system may include at least one processor and a memory coupled to the at least one processor, where the memory stores program instructions, and where the program instructions are executable by the at least one processor to receive a request to render an animation. In some cases, the animation may include a declarative timeline data structure having a plurality of commands. The instructions may also be executable by the processor to parse the plurality of commands, pass each of the parsed commands to an animation function, receive a plurality of run-time commands in response, and render the animation by executing the plurality of run-time commands.
While this specification provides several embodiments and illustrative drawings, a person of ordinary skill in the art will recognize that the present specification is not limited only to the embodiments or drawings described. It should be understood that the drawings and detailed description are not intended to limit the specification to the particular form disclosed, but, on the contrary, the intention is to cover all modifications, equivalents and alternatives falling within the spirit and scope of the claims. The headings used herein are for organizational purposes only and are not meant to be used to limit the scope of the description. As used herein, the word “may” is meant to convey a permissive sense (i.e., meaning “having the potential to”), rather than a mandatory sense (i.e., meaning “must”). Similarly, the words “include,” “including,” and “includes” mean “including, but not limited to.”
A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by any one of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever.
This detailed description first discusses an illustrative animation software program, followed by an example of a graphical user interface for such a program. The description then discloses various techniques for creating and processing declarative timeline data structures, as well as by techniques for parameterizing those timelines. The specification further discloses techniques for using value template within timelines. Lastly, the description discusses a computing system configured to implement certain embodiments disclosed herein. The term “animation,” as used throughout this specification, may include an animation, graphical presentation, multimedia content, advertisement, motion picture, film, movie, cartoon, or the like.
In the following detailed description, numerous specific details are set forth to provide a thorough understanding of claimed subject matter. However, it will be understood by a person of ordinary skill in the art in light of this specification that claimed subject matter may be practiced without necessarily being limited to these specific details. In some instances, methods, apparatuses or systems that would be known by a person of ordinary skill in the art have not been described in detail so as not to obscure claimed subject matter.
Some portions of the detailed description which follow are presented in terms of algorithms or symbolic representations of operations on binary digital signals stored within a memory of a specific apparatus or special purpose computing device or platform. In the context of this particular specification, the term specific apparatus or the like includes a general purpose computer once it is programmed to perform particular functions pursuant to instructions from program software. Algorithmic descriptions or symbolic representations are examples of techniques used by those of ordinary skill in the signal processing or related arts to convey the substance of their work to others skilled in the art. An algorithm is here, and is generally, considered to be a self-consistent sequence of operations or similar signal processing leading to a desired result. In this context, operations or processing involve physical manipulation of physical quantities. Typically, although not necessarily, such quantities may take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared or otherwise manipulated. It has proven convenient at times, principally for reasons of common usage, to refer to such signals as bits, data, values, elements, symbols, characters, terms, numbers, numerals or the like. It should be understood, however, that all of these or similar terms are to be associated with appropriate physical quantities and are merely convenient labels. Unless specifically stated otherwise, as apparent from the following discussion, it is appreciated that throughout this specification discussions utilizing terms such as “processing,” “computing,” “calculating,” “determining” or the like refer to actions or processes of a specific apparatus, such as a special purpose computer or a similar special purpose electronic computing device. In the context of this specification, therefore, a special purpose computer or a similar special purpose electronic computing device is capable of manipulating or transforming signals, typically represented as physical electronic or magnetic quantities within memories, registers, or other information storage devices, transmission devices, or display devices of the special purpose computer or similar special purpose electronic computing device.
To design a new animation, animation engine or module 120 may receive user input 112 requesting that a new animation file or project be created. Thereafter, the user may request, for example, that one or more input objects 110 (e.g., an image, sound and/or video clip) be added to the animation. Examples of image files and formats include JPEG, JFIF, TIFF, RAW, PNG, GIF, BMP, CGM, SVG, PNS, and JPS, among others. The user may then continue to interact with animation engine 120, for example, by changing a property (e.g., a position, color, font, background, opacity, etc.) of the newly added image over time, which may be graphically represented in a “timeline.” Once the animation is complete, the animation engine may create output animation 130 and store it in storage medium 140. As described in more detail below, storage medium 140 may include a system memory, a disk drive, DVD, CD, etc. Additionally or alternatively, animation engine 120 may retrieve input animation 132 from storage medium 140 to allow the user to further develop an existing animation or file.
In some embodiments, animation engine 120 may include a number of routines, algorithms, functions, and/or libraries that expose an application programming interface (API) that allows a user to create an animation, presentation, multimedia file, or the like. For example, in a case where output animation 130 is encoded in a HyperText Markup Language (HTML) file for display on a web browser or the like (e.g., Internet Explorer®, Firefox®, Safari®, Chrome®, etc.), animation engine 120 may include implementations of scripting languages (e.g., JavaScript) and associated libraries (e.g., jQuery) that allow the user to encode an animation within an HTML file using a particular API. More generally, animation engine 120 may include software code that allows the user to implement any number of technologies such as, for example, HTML, Java, JavaScript, Cascading Style Sheets (CSS), Scalable Vector Graphics (SVG), Canvas (a procedural model that updates bit maps in HTML), etc. that may be suitable for animating content. In some embodiments, the functions disclosed in the sections presented below may be performed by animation engine 120 implemented by program instructions stored in a computer-readable storage medium and executable by one or more processors (e.g., one or more CPUs or GPUs).
Animation engine 120 may further include a layout engine (not shown) to enable the rendering of web pages or the like. For example, in certain embodiments, animation engine 120 may include a WebKit module that is configured to display of web content in windows, executes JavaScript, and also to implement other browser features (e.g., clickable links, etc.). In other embodiments, however, any other suitable rendering engine may be implemented as part of animation engine 120.
Turning to
As illustrated, UI 200 includes stage 210 where an animation is graphically developed by the user. For example, the user may open or import one or more images, objects, or “actors” (e.g., input objects 110 of
UI 200 further includes properties window or panel 235 configured to show certain properties that are associated with a selected actor or object (“saladimage,” in this example). In some cases, properties panel 235 may expose object properties that may be modified by a user. For example, if the object is a graphical element, applicable properties may include, but are not limited to, a position, size, color, background, font type, opacity, 2-dimensional transformation (e.g., rotation, translation, etc.), and 3-dimensional transformations, among others. In the case of an audio element, for instance, properties may include, but are not limited to, level, pitch, playback speed, and sound effects (e.g., delay, reverb, distortion, etc.), among others. In some cases, by selecting a particular actor (e.g., on state 210) and modifying a given property in panel 235 that is associated with that actor, UI 200 may allow the user to “animate” that actor.
UI 200 includes timeline panel 240, which enables the user to select an existing timeline or to create a new timeline upon which the animation may be developed. In some embodiments, a designer may develop two or more timelines simultaneously and/or one timeline nested within another. Upon selection or creation of a particular timeline in panel 240, the selected timeline appears in panel 245. In this example, a “default timeline” is shown in panel 245. As illustrated, timeline panel 245 is configured to animate three actors—i.e., “saladimage,” “saladDescription,” and “navbar.” In some embodiments, timeline panel 245 enables a user to add, remove, or select one or more of the available actors to the selected timeline by “dragging-and-dropping” the actor in and out of timeline panel 245. As shown in
In some embodiments, timeline panel 245 may include a “playhead” or “timeline cursor” 250 that indicates the point in time of the animation that is currently playing, or the point where playback will start when the user initiates or plays the animation. In some embodiments, a user may click and drag playhead 250 along the timeline to move to a different portion of the animation. Furthermore, panel 210 may be synchronized with panel 245 such that, while the user moves playhead 250 around, panel 210 approximately simultaneously displays a corresponding portion of the animation.
In some embodiments, panel 245 may include a bar (e.g., bar 260) or some other graphical representation that indicates the start time, end time, and/or duration of the animation of each property of each actor being modified over time. For example, panel 245 shows that the “left” property of the “saladimage” actor begins to be modified at t=0 seconds, and that the “top” property of the “saladDescription” actor begins to be modified sometime after that. The modifications to both properties of both actors ends simultaneously at t=1 seconds. In other words, the different animations of “saladimage” and “saladDescription” occur at least partially in parallel. On the other hand, the modification to the “top” property of the “navbar” actor begins at t=1 seconds and continues on its own afterwards.
In some embodiments, UI 200 may be configured to allow a user to select a portion of a selected bar (e.g., the center, left and/or right edge of bar 260) and move it along the timeline to change the start time, end time, and/or duration of the animation. In addition, panel 245 may also include zoom tool 255 that allows the user to modify the scale of the timeline during the design of the animation.
The timelines depicted in panels 240 and 245 of
In some embodiments, timeline panel 245 depicted in
The second command shown in
The timeline data structure of
In some embodiments, a timeline data structure such as that depicted in
In certain embodiments, a timeline data structure may be an array of elements, and each element may be a command or object that operates upon an actor to animate that actor (or otherwise modify a value of a property of that actor) over time. In some cases, timeline elements may themselves contain other timelines, thus resulting in a data structure that is tree-like. When implemented in animation engine such as engine 120 of
Turning now to
Referring to both
In some embodiments, the method of
In some embodiments, a declarative timeline data structure such as the described in the preceding section may be parameterized in whole or in part. In some embodiments, parameterizing a timeline refers to the replacement of specific actors, properties, values, and/or elements with named generic placeholders or strings. At run-time, the same parameterized timeline may be used (and re-used) to animate and/or modify one or more different actors, properties, values, and/or elements. Additionally or alternatively, the parameterized timeline may use different key frame values create transitions among any number of target values.
Turning to
At 720, the method may replace references to the selected objects within the timeline with one or more corresponding placeholders. In some embodiments, the user may select the string that serves as a placeholder for each parameterized element. In other embodiments, animation engine 120 automatically creates these placeholders. At 730, the method may receive a request to animate or otherwise modify new objects, actors, properties, and/or values that are different from the original ones. For example, a user may wish to substitute “image A” with “image B” in what is otherwise the same animation. At 740, the method may create a correlation between particular placeholders and the new objects, actors, properties, and/or values. This correlation may be achieved, for example, by the use of a dictionary of key/value pairs. In some embodiments, a dictionary may indicate a proper substitution of a placeholder in the parameterized timeline with a reference to the new objects, actors, properties, and/or values to be animated. Further, in some cases such a dictionary may be declaratively defined and/or it may be event-defined (e.g., created “on-the-fly”) as discussed in more detail with respect to
Turning to
Turning to
Turning now to
In some embodiments, parameterization dictionary entries may be created upon events that are at least in part independent from a user's direct action. In some cases, for instance, a key/value entry may be created based on the user's browsing history and/or other information specific to that user. For example, if code within a webpage determines that a user is likely male, an animation may be presented that substitutes a placeholder with a reference to an image of a woman. Conversely, if the code determines that the user is probably female, the animation may replace the placeholder with a reference to an image of a man. In both cases, the underlying timeline that is executed to render the animation may be the same and/or similar. In some embodiments, a parameterized dictionary may have one or more entries generated based on one or more of the user's estimated and/or detected age, social network connections, visited websites, shopping history, etc. In other embodiments, placeholders may be substituted by references to specified actors, objects, properties, values, etc. based on a type of browser, a connection bandwidth, etc.
Although the examples above describe timeline parameterization in term of graphical elements, in other embodiments other types of elements may be parameterized. For example, an audio recording may have properties such as frequency bands, levels, etc. Hence, in an animation where an audio file (e.g., WAV, OGG, RIFF, RAW, AU, 25 AAC, MP4, MP3, WMA, RA, etc.) has one or more property values varying along a timeline (e.g., a dynamic equalizer that changes levels for one or more frequency bands over time), such a timeline may be parameterized with respect to one or more of those properties to enable a user to substitute one audio file for another without creating a separate animation or timeline data structure.
Certain JavaScript frameworks may render an animation within a web browser at least in part by updating specific CSS style properties on one or more DOM elements at regular time intervals. The animation APIs for these frameworks typically allow the developer to specify the name of one or more numeric CSS properties to animate, a “to” value, and optionally a “from” value. These APIs usually restrict support to CSS properties that require a single “length” value that includes of a number and optionally a unit string, but typically cannot handle properties that require two or more numeric/length values and/or properties that have values wrapped with syntactic elements (e.g., “rgba(r,g,b,a)”). Furthermore, CSS presently adds support for more property values that have more complex formats having multiple optional components that may be specified in any suitable order.
Turning now to
In some embodiments, the timeline data structure and/or command may include a value template that adds text or a string to the numerical value produced by the command and yields a combination of the numerical value with the text or string. In some cases, the value template may include a placeholder; in other cases, a key/value dictionary may provide similar functionality. Additionally or alternatively, the value template may also change the format of the numerical value. Examples of such value templates are discussed below with respect to
At run-time, an algorithm similar to that described with respect to
Turning now to
In some embodiments, in addition to providing a string or text to be combined with output numerical values, certain techniques described herein may allow formatting of those numerical values.
In some embodiments, the value template techniques described above may also be used to format or otherwise provide an indication of a particular color space (e.g., RGB, CMYK, grayscale, etc.) manipulated by an animation function. For example, a placeholder may include a color space's corresponding string and/or change the formatting of the numerical values for each color element (e.g., decimal to hexadecimal) that is passed to the animation function.
Embodiments of a system and method for parameterizing timelines, as described herein, may be executed on one or more computer systems, which may interact with various other devices. One such computer system is illustrated by
In the illustrated embodiment, computer system 2100 includes one or more processors 2110 coupled to a system memory 2120 via an input/output (I/O) interface 2130. Computer system 2100 further includes a network interface 2140 coupled to I/O interface 2130, and one or more input/output devices 2150, such as cursor control device 2160, keyboard 2170, and display(s) 2180. In some embodiments, it is contemplated that embodiments may be implemented using a single instance of computer system 2100, while in other embodiments multiple such systems, or multiple nodes making up computer system 2100, may be configured to host different portions or instances of embodiments. For example, in one embodiment some elements may be implemented via one or more nodes of computer system 2100 that are distinct from those nodes implementing other elements.
In various embodiments, computer system 2100 may be a uniprocessor system including one processor 2110, or a multiprocessor system including several processors 2110 (e.g., two, four, eight, or another suitable number). Processors 2110 may be any suitable processor capable of executing instructions. For example, in various embodiments, processors 2110 may be general-purpose or embedded processors implementing any of a variety of instruction set architectures (ISAs), such as the x86, PowerPC®, ARM®, SPARC®, or MIPS® ISAs, or any other suitable ISA. In multiprocessor systems, each of processors 2110 may commonly, but not necessarily, implement the same ISA.
In some embodiments, at least one processor 2110 may be a graphics processing unit. A graphics processing unit or GPU may be considered a dedicated graphics-rendering device for a personal computer, workstation, game console or other computing or electronic device. Modern GPUs may be very efficient at manipulating and displaying computer graphics, and their highly parallel structure may make them more effective than typical CPUs for a range of complex graphical algorithms. For example, a graphics processor may implement a number of graphics primitive operations in a way that makes executing them much faster than drawing directly to the screen with a host central processing unit (CPU). In various embodiments, the methods and techniques disclosed herein may, at least in part, be implemented by program instructions configured for execution on one of, or parallel execution on two or more of, such GPUs. The GPU(s) may implement one or more application programmer interfaces (APIs) that permit programmers to invoke the functionality of the GPU(s). Suitable GPUs may be commercially available from vendors such as NVIDIA® Corporation, ATI® Technologies (AMD®), and others.
System memory 2120 may be configured to store program instructions and/or data accessible by processor 2110. In various embodiments, system memory 2120 may be implemented using any suitable memory technology, such as static random access memory (SRAM), synchronous dynamic RAM (SDRAM), nonvolatile/Flash-type memory, or any other type of memory. In the illustrated embodiment, program instructions and data implementing desired functions, such as those described above for embodiments of an animation module (such as animation module 120) are shown stored within system memory 2120 as program instructions 2125 and data storage 2135, respectively. In other embodiments, program instructions and/or data may be received, sent or stored upon different types of computer-accessible media or on similar media separate from system memory 2120 or computer system 2100. Generally speaking, a computer-accessible medium may include storage media or memory media such as magnetic or optical media—e.g., disk or CD/DVD-ROM coupled to computer system 2100 via I/O interface 2130. Program instructions and data stored on a non-transitory computer-accessible medium may further be transmitted by transmission media or signals such as electrical, electromagnetic, or digital signals, which may be conveyed via a communication medium such as a network and/or a wireless link, such as may be implemented via network interface 2140.
In one embodiment, I/O interface 2130 may be configured to coordinate I/O traffic between processor 2110, system memory 2120, and any peripheral devices in the device, including network interface 2140 or other peripheral interfaces, such as input/output devices 2150. In some embodiments, I/O interface 2130 may perform any necessary protocol, timing or other data transformations to convert data signals from one component (e.g., system memory 2120) into a format suitable for use by another component (e.g., processor 2110). In some embodiments, I/O interface 2130 may include support for devices attached through various types of peripheral buses, such as a variant of the Peripheral Component Interconnect (PCI) bus standard or the Universal Serial Bus (USB) standard, for example. In some embodiments, the function of I/O interface 2130 may be split into two or more separate components, such as a north bridge and a south bridge, for example. In addition, in some embodiments some or all of the functionality of I/O interface 2130, such as an interface to system memory 2120, may be incorporated directly into processor 2110.
Network interface 2140 may be configured to allow data to be exchanged between computer system 2100 and other devices attached to a network, such as other computer systems, or between nodes of computer system 2100. In various embodiments, network interface 2140 may support communication via wired or wireless general data networks, such as any suitable type of Ethernet network, for example; via telecommunications/telephony networks such as analog voice networks or digital fiber communications networks; via storage area networks such as Fibre Channel SANs, or via any other suitable type of network and/or protocol.
Input/output devices 2150 (e.g., “user input 112” in
As shown in
A person of ordinary skill in the art will appreciate that computer system 2100 is merely illustrative and is not intended to limit the scope of the disclosure described herein. In particular, the computer system and devices may include any combination of hardware or software that can perform the indicated functions, including a computer, personal computer system, desktop computer, laptop, notebook, or netbook computer, mainframe computer system, handheld computer, workstation, network computer, a camera, a set top box, a mobile device, network device, internet appliance, PDA, wireless phones, pagers, a consumer device, video game console, handheld video game device, application server, storage device, a peripheral device such as a switch, modem, router, or in general any type of computing or electronic device. Computer system 2100 may also be connected to other devices that are not illustrated, or instead may operate as a stand-alone system. In addition, the functionality provided by the illustrated components may in some embodiments be combined in fewer components or distributed in additional components. Similarly, in some embodiments, the functionality of some of the illustrated components may not be provided and/or other additional functionality may be available.
A person of ordinary skill in the art will also appreciate that, while various items are illustrated as being stored in memory or on storage while being used, these items or portions of them may be transferred between memory and other storage devices for purposes of memory management and data integrity. Alternatively, in other embodiments some or all of the software components may execute in memory on another device and communicate with the illustrated computer system via inter-computer communication. Some or all of the system components or data structures may also be stored (e.g., as instructions or structured data) on a computer-accessible medium or a portable article to be read by an appropriate drive, various examples of which are described above. In some embodiments, instructions stored on a computer-accessible medium separate from computer system 2100 may be transmitted to computer system 2100 via transmission media or signals such as electrical, electromagnetic, or digital signals, conveyed via a communication medium such as a network and/or a wireless link. Various embodiments may further include receiving, sending or storing instructions and/or data implemented in accordance with the foregoing description upon a computer-accessible medium. Accordingly, the present invention may be practiced with other computer system configurations.
The various methods as illustrated in the figures and described herein represent example embodiments of methods. The methods may be implemented in software, hardware, or a combination thereof. The order of method may be changed, and various elements may be added, reordered, combined, omitted, modified, etc. Various modifications and changes may be made as would be obvious to a person of ordinary skill in the art having the benefit of this specification. It is intended that the invention embrace all such modifications and changes and, accordingly, the above description to be regarded in an illustrative rather than a restrictive sense.