This disclosure relates generally to computer software that runs, displays, provides, shares, or otherwise uses electronic content.
Various computer applications are used to create graphics, applications, animations, videos, and other electronic content. Many such applications provide a what-you-see-is-what-you-get (WYSIWYG) interface that allows the appearance of the electronic content being created to be specified on a graphical canvas area. However created, electronic content can involve displaying, animating, or otherwise playing various types of visually-perceptible objects. Geometric shapes, images, pictures, and text are examples of such objects. How such objects are positioned in the electronic content can vary and may depend upon the particular type of electronic content. On web pages, rich Internet applications, and various other types of electronic content, the position of objects is often defined in a creation application with reference to an aspect of the electronic content. For example, an object's position may be defined with respect to distance from one or more of the edges of the electronic content's display area.
While defining object positioning with respect to content edges is useful, it is also often desirable to create and use more complicated object layouts. Content creators, for example, often find it useful to define object positioning with respect to other content objects. For example, all of the individual objects that make up a button may be defined as parts of a single group so that the button can be moved, rotated, resized, or otherwise edited more efficiently in a content creation application. Those individual objects that make up the button may each have a position that is defined by reference to a bounds associated with the entire group of objects. Those bounds may be different from the edges of the electronic content. In one particular example, a button component is implemented as a parent component and the individual objects that make up the button are defined as child components such that their position is defined relative to bounds associated with the parent button component.
One exemplary embodiment involves receiving, in an electronic content creation application provided on a computer device, input for an object of electronic content being edited in the electronic content creation application. The input modifies a position attribute or a size attribute of the object in at least one state of the multiple states relative to bounds that is the same for multiple states of the object. The electronic content creation application determines whether to update the bounds associated with the object based on the input and, if updating the bounds is necessary, it updates the bounds associated with the object and, based on the update of the bounds, updates the position attribute or the size attribute.
A second exemplary embodiment involves receiving, in an electronic content creation application provided on a computer device, input for an object of electronic content being edited in the electronic content creation application. Prior to the input, there was a first association between the object and the first bounds such that changing the first bounds changes a position attribute or a size attribute of the object. Based on the input, the electronic content creation application determines to remove the first association and create a second association between the object and the second bounds such that changing the second bounds changes the position attribute or the size attribute of the object. The electronic content creation application also creates a third association between the second bounds and the first bounds such that changing the first bounds changes the second bounds to preserve a position or size of the object relative to the first bounds.
These illustrative embodiments are mentioned not to limit or define the disclosure, but to provide examples to aid understanding thereof. Additional embodiments are discussed in the Detailed Description, and further description is provided there.
These and other features, aspects, and advantages of the present disclosure are better understood when the following Detailed Description is read with reference to the accompanying drawings, where:
Methods and systems are disclosed that manage the positioning and sizing of objects in electronic content. One exemplary embodiment facilitates the creation and editing of a parent object that has a position and size or bounds that is defined by its child objects. The bounds of such a parent object may be adjusted during editing of the electronic content in ways such that the bounds is the same across all of the multiple states. Thus, an edit made with respect to one state may result in a change to the bounds across all states. In many circumstances, it is desirable to ensure that all child objects are within the bounds of the parent object. It may also be desirable to minimize the bounds such that, for example, the bounds provides a rectangle of minimum dimensions that is constant across the multiple states but that encompasses each of the child objects in any of the states. When electronic content is edited, the bounds may be adjusted to ensure that these requirements are satisfied. Thus, moving a child object may result in the bounds of the parent object being extended or reduced in one or more direction to accommodate the new position of the child object.
Managing the positioning and sizing of objects in multi-state electronic content may also involve managing constraints. Constraints are attributes that define the position or size of an object in one or more states relative to a bounds. Constraints are particularly useful when used in resizable parent objects that have child objects the positions of which are constrained relative to one or more bounds of the parent. When the parent is resized and the bounds is changed, the child objects are repositioned and/or resized according to the constraints. Thus, if a text object is constrained to a position 50 pixels from the right edge of its parent window object, when the window is resized by an end-user of the electronic content, the text will move to maintain the 50 pixel distance from the right edge of the parent window object.
Managing the positioning and sizing of objects in multi-state electronic content may also involve responding to edits of the electronic content that constrain child objects, editing the visual bounds of child objects, or adding child objects. Such edits may result in updating the origin and/or size of the parent object to ensure that all its child objects remain within its bounds in all of its different states. If the origin of such a parent object bounds is updated, corresponding updates may be made to any child object attribute that refers to the updated bounds. Thus, if positions of a child objects are specified as a constraint relative or an edge or as an x/y position relative to an origin, these references can be changed based on changes to the parent object bounds. As specific examples, left/top constraints and x/y positions of the child objects can be adjusted to prevent those objects from moving in an unintended manner.
Managing the positioning and sizing of objects in multi-state electronic content may also involve preventing collapse and other errors. Electronic content may be developed with a parent object and child objects whose sizes depend upon one another, i.e., objects the positions and sizes of which are recursively defined. Managing the positioning and sizing of objects can involve preventing such definitions from causing errors. For example, in applying constraints, the width and/or height of a parent object can be managed so that objects do not collapse in on themselves based on an edit. For example, if a first object has a right constraint, when the user adds or removes another object that defines the right/bottom edge, the size of the first object and right/bottom constrained objects may be adjusted to prevent a collapse or other error.
Generally, managing the positioning and sizing of objects in multi-state electronic content by automatically managing bounds and/or object attributes can provide various benefits. For example, it may help keep the electronic content stable across multiple states and prevent objects from collapsing and/or moving in unexpected ways in response to edits. One embodiment provides an on-the-fly, multi-state adjustment in response to edits received from a user that makes it simpler for content creators to create electronic content. One embodiment provides a user interface that allows a content creator to use the automatic adjustment features or to alternatively manually adjust bounds. Where bounds are manually adjusted the content creation application can update any object constraints or other attributes to ensure that objects respond as expected in response to the changed bounds.
As used herein, the term “device” refers to any computing or other electronic equipment that executes instructions and includes any type of processor-based equipment that operates an operating system or otherwise executes instructions. A device will typically include a processor that executes program instructions and may include external or internal components such as a mouse, a CD-ROM, DVD, a keyboard, a display, or other input or output equipment. Examples of devices are personal computers, digital assistants, personal digital assistants, cellular phones, mobile phones, smart phones, pagers, digital tablets, laptop computers, Internet appliances, other processor-based devices, and television viewing devices. The exemplary device 10 is used as a special purpose computing device to provide specific functionality offered by its applications. As an example, device 10 is shown with a display 18 and various user interface devices 19. A bus, such as bus 16 will typically be included in a device.
As used herein, the phrase “electronic content” refers to any text, graphics, video, audio, application, executable code, or other material that can be stored on and/or presented on or through a computer or other device. A piece of electronic content can be provided as one or more electronic files and developed as part of a single content creation project. An electronic content creation application may open such electronic content for editing, for example, such that edits made using the electronic content creation application result in changes to the one or more electronic files that define or otherwise make up the piece of electronic content being created.
As used herein, the term “object” refers to any component, representation, graphic, element, or anything else that is or can be displayed as a part of electronic content. An object may comprise features and attributes that define, specify, influence, or affect how the item appears, behaviors, or is otherwise used in electronic content. An object may have features and attributes that include one or more other objects within the item or that otherwise associate the object with one or more other objects, for example, though a parent/child relationship.
As used herein, the term “multi-state content” refers to content in which the content itself and/or one or more objects of the content are associated with more than one state. Each state specifies a particular configuration, relationship, and/or selection of properties for objects associated with that state. A given object may be associated with one or more of states in multi-state content. In some, but not all, electronic content different states are associated with different positions along a timeline. In some, but not all, electronic content different states are associated with different events determined during use of the content. As a specific example, a button object might be associated with an “up” state and a “down” state.
As used herein, the term “application” refers to any program instructions or other functional components that execute on a device. An application may reside in the memory of a device that executes the application. As is known to one of skill in the art, such applications may be resident in any suitable computer-readable medium and execute on any suitable processor. For example, as shown the device 10 comprises a computer-readable medium as memory 12 coupled to a processor 11 that executes computer-executable program instructions and/or accesses stored information. Such a processor 11 may comprise a microprocessor, an ASIC, a state machine, or other processor type, and can be any of a number of computer processors. Such a processor comprises, or may be in communication with a computer-readable medium which stores instructions that, when executed by the processor, causes the processor to perform the steps described herein.
A computer-readable medium may comprise, but is not limited to, an electronic, optical, magnetic, or other storage device capable of providing a processor with computer-readable instructions. Other examples comprise, but are not limited to, a floppy disk, CD-ROM, DVD, magnetic disk, memory chip, ROM, RAM, an ASIC, a configured processor, optical storage, magnetic tape or other magnetic storage, flash memory, or any other medium from which a computer processor can read instructions. The instructions may comprise processor-specific instructions generated by a compiler and/or an interpreter from code written in any suitable computer-programming language, including, for example, C, C++, C#, Visual Basic, Java, Python, Perl, JavaScript, and ActionScript.
In
One exemplary embodiment involves managing the positioning and sizing of objects in multi-state electronic content by calculating bounds after each edit that could affect the size or position of an object. In an exemplary content creation application, before the user begins editing, each of the different states is assessed and information about bounds is stored. In response to edits that could affect the position or size of the object, the application recalculates the visual bounds in the current state and then determines a union of all the bounds across all the states to determine whether or not to adjust to the origin and/or size of the bounds. Bounds in any one state could be determined, for example, by combining the individual bounds of all children. As a specific example, bounds can be determined by iterating through and adding all the direct children of the parent. Preferably, this includes the entire stroke and any constraints. If the origin needs to be updated, the application adjusts all the position and/or size attributes of the objects according to predetermined rules. For example, left/top constraints and x/y values of the child objects can be adjusted. An example of updating size involves adjusting right/bottom constraints so that constrained items do not move with the changing edge. The application may use optimization or caching strategies such that bounds are recalculated only in response to some edits. In one exemplary application, a content creator can turn off such automatic bounds adjustment features to manually manage bounds. The application may present one or more graphical representations that allow bounds to be adjusted directly on a WYSIWYG interface. When the bounds are changed, the application may adjust any affected objects to account for the new bounds, for example, so that the objects are not inadvertently moved to new positions. Alternatively, the application may choose to not adjust any objects, allowing the updated bounds to cause the object to change position and/or size.
The exemplary method 200 further involves determining whether to update the bounds associated with the object based on the received input, as shown in block 220. Determining whether to update the bounds or not may depend on whether the input results in an edit that moves or otherwise positions the object beyond the bounds or not.
Determining whether to update the bounds or not may additionally or alternatively depend on whether the input is of a particular type. For example, a movement of an object on a WYSIWYG interface beyond a bounds may be interpreted as associated with an intention to expand the bounds while input specifying negative value for an object's position or constraint may be interpreted as associated with an intention to position an object outside of the bounds. For example, to specify an animation involving an object moving in from outside of a window, a first state may include the object outside of the bounds and a second state may include the object within the bounds.
Returning to
The exemplary method 200 of
Managing the positioning and sizing of objects in multi-state electronic content may also involve facilitating manual bounds adjustments. In one exemplary embodiment, an electronic content creation application receives a command to manually manage bounds. It may then receive a second input modifying the bounds. Given this second input modifying the bounds, the content creation application determines whether to update the position attribute or the size attribute of one or more of the objects in the multiple states. While the electronic content creation application is in such a manual bounds management mode, it will not automatically update the bounds based on input modifying the position attribute or size attribute of the object associated therewith. Thus, a content creator may switch to such a manual mode as a convenient mode in which objects can be moved without changing the bounds, for example, to move an object outside of the bounds in a particular state. The provision of both an automatic bounds feature and a manual mode can provide flexibility, ensure that editing of content does not produce unexpected bounds or object behavior.
Methods and systems are disclosed that manage the positioning and sizing of objects in electronic content that can provide certain features that facilitate reparenting of objects. Such systems and methods are generally useful for groups of objects whose size and/or positions is defined relative to a set of bounds. Since multiple sets of bounds may exist within a given piece of electronic content being created, it is often desirable to change the set with which one or more objects is associated. In this context, a “parent” is any object that defines or provides a set of bounds regardless of whether there is literal parent-child containment. Accordingly, a reparenting action can change the association of bounds for one or more objects. For example, moving an object from one parent to another can change the set of bounds to which that object is associated. In addition, one set of bounds may be defined relative to another set of bounds, for example if one of a parent's children is itself a parent. In some circumstances, each of the different sets of bounds in electronic content being developed can be interpreted relative to an absolute frame of reference, for example, bounds of entire piece of electronic content being developed, e.g., where an outermost parent defines such bounds.
Reparenting may also involve preserving the reparented object's layout behavior, i.e. how its size and position changes as the various bounds are adjusted. To preserve this, both the object's size and position constraint and the new parent's own size and position constraints may be adjusted. In one embodiment, if a given edge or other anchor point of the object was defined relative to an edge of the original parent's bounds, that edge or point of the object may be made relative to the same edge on the new parent's bounds, and that edge of the parent's bounds may be made relative to the original edge on the original parent's bounds. This creates an unbroken chain of constraints from the edge or point of the object to the original bounds edge.
Numerous specific details are set forth herein to provide a thorough understanding of the claimed subject matter. However, those skilled in the art will understand that the claimed subject matter may be practiced without these specific details. In other instances, methods, apparatuses or systems that would be known by one of ordinary skill have not been described in detail so as not to obscure claimed subject matter.
Some portions are presented in terms of algorithms or symbolic representations of operations on data bits or binary digital signals stored within a computing system memory, such as a computer memory. These algorithmic descriptions or representations are examples of techniques used by those of ordinary skill in the data processing arts to convey the substance of their work to others skilled in the art. An algorithm is a self-consistent sequence of operations or similar 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 and similar terms are to be associated with appropriate physical quantities and are merely convenient labels. Unless specifically stated otherwise, it is appreciated that throughout this specification discussions utilizing terms such as “processing,” “computing,” “calculating,” “determining,” and “identifying” or the like refer to actions or processes of a computing device, such as one or more computers or a similar electronic computing device or devices, that manipulate or transform data represented as physical electronic or magnetic quantities within memories, registers, or other information storage devices, transmission devices, or display devices of the computing platform.
The system or systems discussed herein are not limited to any particular hardware architecture or configuration. A computing device can include any suitable arrangement of components that provides a result conditioned on one or more inputs. Suitable computing devices include multipurpose microprocessor-based computer systems accessing stored software that programs or configures the computing system from a general purpose computing apparatus to a specialized computing apparatus implementing one or more embodiments of the present subject matter. Any suitable programming, scripting, or other type of language or combinations of languages may be used to implement the teachings contained herein in software to be used in programming or configuring a computing device.
Embodiments of the methods disclosed herein may be performed in the operation of such computing devices. The order of the blocks presented in the examples above can be varied—for example, blocks can be re-ordered, combined, and/or broken into sub-blocks. Certain blocks or processes can be performed in parallel.
The use of “adapted to” or “configured to” herein is meant as open and inclusive language that does not foreclose devices adapted to or configured to perform additional tasks or steps. Additionally, the use of “based on” is meant to be open and inclusive, in that a process, step, calculation, or other action “based on” one or more recited conditions or values may, in practice, be based on additional conditions or values, beyond those recited. Headings, lists, and numbering included herein are for ease of explanation only and are not meant to be limiting.
While the present subject matter has been described in detail with respect to specific embodiments thereof, it will be appreciated that those skilled in the art, upon attaining an understanding of the foregoing may readily produce alterations to, variations of, and equivalents to such embodiments. Accordingly, it should be understood that the present disclosure has been presented for purposes of example rather than limitation, and does not preclude inclusion of such modifications, variations and/or additions to the present subject matter as would be readily apparent to one of ordinary skill in the art.