COMMENT SYSTEM FOR INTERACTIVE GRAPHICAL DESIGNS
Various methods and systems for collaborating on the specification of an interactive graphical design are provided. An exemplary system comprises a graphical design environment. The system also comprises a note interface in the graphical design environment that displays a note field for accepting a text string from the user. The system also comprises a design player that renders the design. The system also comprises a discussion interface that: (i) is displayed in the design player consistently with the design; (ii) displays the text string from the user as a note; and (iii) accepts a comment from a second user regarding the note. The system also comprises a data store accessible to the graphical design environment and the design player. The comment is displayed in the graphical design environment after being accepted in the discussion interface.
This application is a continuation of U.S. patent application Ser. No. 14/564,022, filed Dec. 8, 2014, which is a continuation of U.S. patent application Ser. No. 14/201,161, filed Mar. 7, 2014, now U.S. Pat. No. 8,938,679, which claims the benefit of U.S. Provisional Application No. 61/905,846, filed Nov. 18, 2013, which are both incorporated by reference herein in their entirety.
BACKGROUND OF THE INVENTIONComplex interactive graphical designs require collaboration among numerous professionals with wide ranging skill sets. As the complexity of these designs increase, the number of stakeholders involved in the design increases along with the level of specialization they each exhibit. It is therefore of increasing importance for design tools to facilitate a liquid and frictionless flow of information between each member of the collaborative team so that each stakeholder can apply their skills to the design process while the team remains focused on a common understanding of what the final design will be.
Along with diverging specialties, teams expect to be provided with an environment for fluid collaboration even when the team members are located in diverse geographical locations. Design tools currently approach this problem by providing stakeholders with the ability to add notes to a design for later review by other members of the team. For example, a project manager can instruct a graphical design professional on the team to modify the appearance of an image while a graphical designer can instruct an interface specialist to make the image appear in a light box when a button in the design is selected. The graphical designer and interface specialist could then each enter the design at a later time, read the content of the notes, and edit the design as instructed.
Design tools have previously facilitated collaboration through various approaches. Simple graphical designs tools, such as those used for producing text documents, can allow for collaboration through the introduction of comments and specialized notation systems for tracking changes. More complex design tools, such as those used to edit the design of a web site, allow for collaboration through the use of a comment pane that can appear along the side of a web page as it is being rendered in a browser. The comment pane allows multiple users to communicate textually regarding the design. For example, one user may view the design and add a comment on one aspect of the design which is then read by a second user.
An example of a collaborative tool for commenting on an interactive graphical design in the specific context of a website design can be described with reference to web browser screen 100 in
In one embodiment, a system comprises a graphical design environment that provides a drag and drop interface to a user. The user can add a widget to a design using the drag and drop interface. The system also comprises a note interface in the graphical design environment that displays a note field for accepting a text string from the user. The system also comprises a design player that renders the design. The system also comprises a discussion interface that: (i) is displayed in the design player consistently with the design; (ii) displays the text string from the user as a note; and (iii) accepts a comment from a second user regarding the note. The system also comprises a data store accessible to the graphical design environment and the design player. The comment is displayed in the graphical design environment after being accepted in the discussion interface. The comment and a second comment are delivered to the user via email after the comment is accepted in the discussion interface. The text string is stored in the data store, and is restricted such that it can only be edited by a predetermined set of users.
In another embodiment, a system comprises a graphical design environment that provides a drag and drop interface to a user. The user can add a widget to a design using the drag and drop interface. The system also comprises a note interface in the graphical design environment that displays a note field for accepting a text string from the user. The system also comprises a design player that renders the design. The system also comprises a discussion interface that: (i) is displayed in the design player consistently with the design; (ii) displays the text string from the user as a note; and (iii) accepts a comment regarding the note from a second user. The system also comprises a data store accessible to the graphical design environment and the design player. The system also comprises a scrollbar for the discussion interface. The scrollbar allows the second user to scroll through a set of notes that are associated with the design while viewing a fixed portion of the design. The set of notes includes the note. The comment is displayed in the graphical design environment after being accepted in the discussion interface. The comment is delivered to the user via email after being accepted in the discussion interface. The text string is stored in the data store.
In another embodiment, a computer-implemented method comprises generating a graphical design environment for a user. The graphical design environment enables the user to specify a design and add a widget to the design. The method also comprises receiving a text string from the user via the design environment. The text string is stored as a note in a data store. The method also comprises generating an instantiation of the design for rendering in a design player as a rendered design. The rendered design includes the note. The method also comprises receiving a second text string from a second user via the design player. The second text string is stored as a comment on the note in the data store. The method also comprises displaying the comment in the graphical design environment after the comment is received in the design player in the receiving step. The method also comprises delivering the comment and a second comment to the user via email after the comment is received in the design player in the receiving step. The data store is accessible to both the design player and the graphical design environment. The text string is restricted such that it can only be edited by a predetermined set of users.
In additional embodiments, various methods and systems for collaborating on the specification of an interactive graphical design are provided. For example, messages can be sent to stakeholders in the design when comments or notes are added. As another example, the state of the design can be saved when a comment or note is added to the design and saved to facilitate collaboration at a later time. The state of the design can be saved in an abstracted form such as by saving an image of the design's state. The state of the design can also be saved in the form of executable code that can be used to render the state of the design in a player at a later time. Numerous additional embodiments for facilitating the collaborative specification of an interactive graphical design are provided in the detailed description below.
Reference now will be made in detail to embodiments of the disclosed invention, one or more examples of which are illustrated in the accompanying drawings. Each example is provided by way of explanation of the present technology, not as a limitation of the present technology. In fact, it will be apparent to those skilled in the art that modifications and variations can be made in the present technology without departing from the spirit and scope thereof. For instance, features illustrated or described as part of one embodiment may be used with another embodiment to yield a still further embodiment. Thus, it is intended that the present subject matter covers all such modifications and variations within the scope of the appended claims and their equivalents.
In
Design environment 200 may display a widget specification interface in many different forms. For example, the widget specification interface could take up separate regions of design environment 200 or be limited to a single contiguous location. As another example, the widget specification interface could be displayed permanently as part of the design environment interface or could only be displayed in response to an input from the user to trigger the display of the widget specification interface in whole or in part. The widget specification interface could include a widget tool bar from which widgets could be selected and dragged into design interface 202. In the context of web design, the widget could be a button, a menu, a text field, a text box, a display window, a link, or any other design element for a web page.
Properties of individual widgets can be specified in widget property specification interface 204. As illustrated, the absolute position of the widget, the name of the widget, and two properties can be specified in widget property specification interface 204. The widget property specification interface can switch its contents in real time as a user selects different widgets in design interface 202. The widget that is currently selected can be offset visually from the other widgets in the design by surrounding the widget with a selection reticle or by altering the transparency or opacity of the selected widget relative to the other elements in the design. As illustrated, text field 205 is the currently selected widget which is shown by the selection reticle 206 and the fact that widget property specification interface 204 is populated with the values specified for the properties of text field 205. The widget property specification interface can also be linked to the selected widget via the display of numbered footnotes displayed on the widget and displayed in widget property specification interface 204.
Method 300 continues with step 304 in which a text string is received from a user for a notation field of a note linked to a widget. The text string can be received via routing system 404 in
In
As illustrated, note 208 is linked to text field 205 as indicated by selection reticle 206. Notes can be linked to widgets via other symbols such as an alpha numeric footnote that would appear in proximity to both the note and widget. For example, a footnote with the number 1 could appear in the corner of text field 205 and in note interface 207 near note 208. Notes can also be linked to widgets via lines drawn across design environment 200 from the note to the widget. The lines or symbols can appear as soon as text is entered into the note or once a return key or other input is received from the user to indicate completion of the text entry. The input could be the selection of any point in design environment 200 that is not in note interface 207. Such approaches would be best suited to situations where notes were inherent properties of widgets in the design environment such that widgets already had notes even before receiving an input from the user to associate them with a note.
In
The notation fields can accept other kinds of inputs in addition to basic text strings. For example, the notation field can accept text strings with rich formatting. The notation fields could also accept hyperlinks and include automatic text editing features such as automatic spell check and the automatic instantiation of a hyperlink if text is entered that would indicate the text was likely a hyperlink. The notation field could also allow users to enter files for attachment. For example, the users could attach an image file representing the current state of the design when the note was edited. As another example, users could attach video files that illustrate how they envision the interactive features of the design to take place. As another example, users could attach files that include instructions for rendering a series of interactions in a player such as a web browser. The instructions could allow a user to “play” a rendering of an interactive session in which a hypothetical viewer interacted with the design in a particular manner. The design would then be rendered as if it were under the control of a viewer interfacing with the design in that particular manner. The user that was “playing” the rendering could then pause the playback and interact with the design from that point in the playback. As a result, the experience of the user would diverge from the experience of the hypothetical viewer from that point onward.
In
In
Method 300 continues with step 305 in which an instantiation of the design is generated for rendering in a player as a rendered design. Generation step 305 could involve the creation of a coded representation of the design through an export process. The coded representation serves to effectively export the design from the design environment because the coded representation can exist and be rendered apart from the design environment. The coded representation could also be exported and saved to a memory and then later on be retrieved for rendering in a player. Generation step 305 could also involve the real time use of the code used to render the design in design environment 200 to serve a rendering of the design to the player from a web server. In this way, the design could be used to render an end user experience without generating an intermittent coded representation of the design. In situations where the design was exported and stored as an intermittent coded representation, the rendered design would not comprise widgets but would instead comprise coded representations of those widgets. However, in the remainder of the discussion the term “widget” will be used to encompass both widgets and coded representations of widgets when used in the context of a rendered design rather than a design in the tool. In any of these situations, the instantiation of the design that is rendered would include a note that was added while the design was being specified in the design environment.
In the context of the design of web pages, the player could be an external player such as a standard web browser and the instantiation of the design could be a markup and style sheet language description of the design. In this situation, the note could be included in the markup description of the design or it could be included in a script that was referenced by the markup description. The player could also be a reader that is part of the overall design tool such that the design environment 200 and the player were designed to access a common database from which the design tool could allow users to specify the design and from which the reader could allow viewers to view the design. The player could operate on a design with a proprietary format and be used specifically for playing designs from design environment 200. The player could also be a web browser with an add-on that is specifically designed to render notes created in design environment 200 such that the add-on was used to render the notes along-side the rendering of the design in the unmodified web browser.
In
Discussion interface 212 can also include a button 215 that can be selected to allow viewers to add additional notes to the design. When selected, button 215 can trigger the appearance of a pop up window allowing the viewer to enter a text string or attach files that will comprise the contents of the note. The note can then be generically linked to the design or it can be associated with a specific widget. The note can be associated with a widget by placing the rendered design 211 into a state where selection of a widget by a viewer indicates the user's intention to associate the note with the widget. The design can be placed in this state when the discussion interface 212 is first displayed, as soon as button 215 is selected, or when a separate interface element is selected in the pop up window. After selecting the interface element in the pop up window, the next click from the viewer could associate the note with the widget on which the user clicked. The pop up window could also have an indicator for finalizing the note such as a “Complete” or “Submit” button. If a viewer selected this button before associating the note with a widget, the note would be linked to the design in general and not be linked to any specific widget.
The discussion interface could also allow users to add comments to the notes. These comments could appear within the graphical space set off for the note and be indented or be in a smaller font to set them off from the original note. The comments could be added by selecting a button displayed in the note area or could be added any time a user selected the note and began inputting text. The identity of the viewer entering the comment could also be added to the note in order to keep track of who was adding information to the note. The identifiers for the viewers that entered the comments can mirror the identifiers for the stakeholders that entered the original note as described above. For example, the comments could be identified using a text string of the stakeholders name and may also include the class of stakeholder to which that particular stakeholder belongs.
The use of comments added to specific notes would exhibit certain benefits over requiring viewers to add additional notes to the design because comments relating to the same note are thereby collaboratively sorted with little effort on the part of the various stakeholders involved in the project. Multiple comments can be added to the note in order to facilitate multiple layers of collaborative effort directed to the widget in question. Also, comments can be added to comments to create comment threads which would be particularly useful for channeling and organizing multiple conversations regarding a widget. As illustrated, the comment added by the security expert was in direct response to the note provided by the designer from within the design environment while the comment added by the interface expert may trigger the next step in the design flow by suggesting an alternative modification to the widget. In this way, the comments added to a note can respond to the stakeholder that initiated the conversation through the creation of the note, and can also push the design process further by continuing the conversation.
Viewers do not need to be simultaneously viewing a design in order for these comments to be shared with all of the stakeholders in the design process. For example, the security expert on the team could have added their comment while viewing the design and the comment would appear in rendered design 211 the next time a viewer accessed the design for rending in the player. In the illustrated situation, the next viewer was an interface expert that was able to add a comment regarding additional modifications to the widget in the same conversation. The application of both comments to this note is beneficial because they are both modifications that might be made by the same stakeholder. If the interface expert had wanted to add information relating to a different aspect of the design, such as a question for the project manager regarding whether or not the password field should even be on the current page, the interface expert could have added an additional note by pressing button 215 to start an additional conversation.
Allowing stakeholders to view and add comments to notes in a player offers several benefits. First, with more complex designs, not every stakeholder may have the necessary tools for editing certain aspects of the design. In other words, not every stakeholder may have access to design environment 200 or have the wherewithal to understand how the design works unless it is being rendered in a player. Returning to the example of web site design, certain non-technical stakeholders may only have access to, or be proficient in the use of, a web browser while they do not have experience with or access to the more complex design tools used by technical stakeholders for specifying a web site design. As a result, the appearance of the design in either the tool or the viewer may be very different and comments directed to the appearance of the design in the external player might not be relevant to a viewer of the design in the design environment and vice versa. Allowing for the addition of comments in the external viewer allows non-technical stakeholders to conveniently add information to the design process in context which facilitates their review and deploys that information in a manner that is tightly bound to the continuing flow of the design process.
Note 213 is illustrated as having two comments with basic text string inputs. However, comments can, in large part, mirror the content of the notes themselves as described above. For example, the comments can include hyperlinks and text with rich formatting. The comments can also include hyperlinks to a version of the design being rendered in a particular state to which the comment is relevant. The comments can also include image file attachments illustrating a point to which the comment is directed. The image could be of an alternative way for the design to be configured. The comments can also include the “playbacks” mentioned above with reference to the notes that can be used to illustrate a specific rendering of the design.
Notes and comments can be displayed in the external player in various ways. As illustrated in
Notes and comments can include various states and status indicators to facilitate management of action items associated with the notes and comments. The notes and comments can be restricted such that they can only be edited by specific stakeholders or a specific class of stakeholders. The notes and comments can also be deleted, and can be restricted so that only a specific stakeholder or a specific class of stakeholders can delete the note or comment. The individual notes and comments can also include selectable icons to indicate that the comment should be closed because it is not currently relevant or has been addressed by the appropriate stakeholder. Access to these icons may be restricted to particular stakeholders and the viewer or user that creates the note can determine which stakeholders should have access to close their particular comment or note. Once closed, the comments could be capable of being reopened if the icon is selected a second time. The restrictions mentioned above can be set on a global basis by a system administrator stakeholder or they can be set by the user or viewer that creates the note or comment. The individual notes and comments could also include selectable icons that would allow stakeholders to apply different statuses to their comments and notes. For example, a stakeholder could click on a pull down menu icon and selected a red flag icon to indicate that the comment or note is urgent. The appearance of the comment or note could change in response to the selection of the comment or notes status. For example, setting the priority of a comment to urgent could change the appearance of the note such that the entire note was outlined in red. As another example, setting the priority of a comment to urgent could change the appearance of the comment so that the comment text appeared highlighted in red. The individual notes and comments could also include selectable icons that would allow stakeholders to determine which class of stakeholders needed to be alerted to the comment. For example, a viewer could select a “security expert” or “graphical designer” class for the comment or note in which case the appearance of the note could change to reflect this such as appearing in blue highlighting if the “security expert” class was selected. Selection of the class of stakeholders or individual stakeholder to which the comment applies could also trigger the delivery of messages to that particular stakeholder or class of stakeholders as described below.
The relationship of notes and widgets can be shown through any kind of visual indicator. As illustrated, the link between note 213 and text field 205 is shown by line 216. However, other indicators can be used such as matching numbered alphanumeric footnotes or a matching reticle surrounding the note and widget simultaneously. Essentially any indicator used to show a link between a note and a widget in the design environment can also show a link between a note and a widget in the external player and vice versa. However, and as shown by the figures, the same type of indicator does not need to be used in both situations. Furthermore, as described below, it is possible to display a single note at a time in which case the relationship of the note and the widget can be illustrated without indicators as the relationship is implied by the common display of both the widget and note at the same time.
The indicators may only appear when certain notes are selected, or the visual indicators may be permanently displayed. For example, the discussion interface 212 could include a scroll bar for moving through the comments and only the notes that were currently displayed on the screen would include visual indicators linking them to widgets in the design. A separate visual indicator such as a highlighted outline around the note could indicate that the widget to which the note applies was not currently being displayed in the rendered design. In these instances, a hyperlink could be automatically added to the note that would link to a rendering in which the widget did appear. A note related to a widget can also appear whenever a viewer hovers their mouse over an icon such as note icon 217. In these situations, only the notes that are associated with the widget to which the note icon is attached will be displayed. This approach is illustrated in
Method 300 continues with step 306 in which the design information flow is completed. To this end, a second instantiation of the design is generated for editing in the design environment. The second instantiation can be generated by processing system 401 in
The ability of the note to flow through the cycle from design environment to player and back produces certain benefits. As mentioned previously, not all stakeholders will have access to, or be proficient in, the use of the design environment so they will only be able to review and comment on the design using a player. However, the comments made by the stakeholders in the player will in large part need to be acted upon by a user in the design environment. The passage of the note and comments back into the design tool therefore creates a more liquid design communication process because the users of the design tool are able to access comments made in the player while they are operating the design tool. Also, the specification of a design is generally an iterative process in which changes are made by users in the design tool and stakeholders suggest modifications on those changes etc. As the comments are able to survive a full cycle of the design tool, they are then able to accompany the design through this iterative process and provide a framework for which the conversation regarding the necessary iterations can be organized and sorted. Stakeholders will be able to track this process in a straight forward manner and recall the motivation for certain changes in the design. This can provide context to the users as they are making the next step of design changes. For example, a user will avoid changing the design to a condition that was previously rejected by other stakeholders which will eliminate unnecessary cycles of the design process.
Instead of marking the note as completed, the user could also have marked the individual comments completed while keeping the note open. The user could then have added an additional comment to the note reminding the security expert and interface expert to check to see if the changes were acceptable. In this way, specific methods that are in accordance with method 300 allow for a flexible and iterative design process that allows stakeholders to continuously stay informed regarding how the design flow is progressing and what their responsibilities are for moving the process forward.
The comments and notes can be stored in a database that is common to both the design environment and the player. In these situations, the comments and notes can appear in real time in the design environment and the player. As a result, viewers and users can be modifying and commenting on the design simultaneously as one stakeholder operates the design tool and the other views the design in a player. In other approaches, notes, comments, and modifications to the design made in the design environment need to be affirmatively pushed by the viewer or user to be added to the common database. In other approaches, the instantiation of the design that is being rendered in an external player is converted back into an encoded a format for being operated on in the design environment. For example, a markup language encoding of an exported design can be converted back into an instantiation in the format used by the design environment along with any comments and notes that have been added to the design since the markup language was initially produced. The converted instantiation can then be saved to a disk and imported back into the design environment. The notes and comments can be included in the markup language encoding of the design or they can be stored separately with an indication of where they are relevant in the design and then be linked back to the design as part of the importing process.
Additional features facilitate the general flow of information between various stakeholders and the interactive design process that is provided by method 300 as described above. The state of the design as a comment or note is added can be saved and attached to the comment or note in various formats. Links in the comments or notes can draw the user or viewer to the point of the design related to the content of the comment or note. Messages regarding the addition of comments or notes to the design can be pushed to various stakeholders by users and viewers and those stakeholders can configure a subscription to the design process by which various changes to the design, comments, and notes can be automatically sent to them.
Whenever a note or comment is added to the design, the current state of the design as it is being specified or rendered can be saved. This saved version of the design or design rendering can then be linked to the comment or note in memory to be recalled at a later time. These states can then be accessed via documents attached to the comments or notes or via links that are placed in the comments or notes. For example, the state could be an image file showing how the design rendering appeared at the time the comment or note was added. The image file could also include additional markings such as with a standard graphical editing tool that a user or viewer is able to open as soon as the comment or note is added to the design. For example, a viewer could add a comment describing how they wanted the design to appear, trigger the graphical editing tool to appear, draw on an image of the design, and then save the edited image so that it is easily accessible to anyone that views the note or comment at a later time. Viewers can also record a portion of their interaction with the design and store the playback with the note or comment as an attachment added to the note or comment or a link added to the note or comment. Users and viewers can also insert links in the notes or comments that link the note to a portion of the design to which the comment relates to. This linking function can also be aided by the design tool. For example, a menu widget may appear in the design tool in various states based on which aspect of the menu widget is being edited. If a user in the viewer adds a note or comment regarding a submenu link that only appears when the menu is in a given state, a link can be added to the note or comment to place the widget in that state in the design tool so that the user can click the link and immediately begin editing that aspect of the widget.
The approaches described in the previous paragraph exhibit various benefits. In particular, the saved states, and easy access thereto provided by attachments and links, allow the comments and notes to remain relevant regardless of how the design changes. As the interactive graphical design goes through various design iterations it may be difficult for subsequent viewers and users to understand what a prior stakeholder was referring to when they added a comment because there comment might no longer be relevant to the current state of the design. However, by including quickly accessible information that describes the state of the design when the comment was made, subsequent viewers and users can more easily put the notes and comments into context and understand the intent of the note or comment. These benefits are particularly relevant to the field of interactive graphical designs because a comment may only be relevant to the design after a number of interactions have been performed and displaying the comments without having put the design in a state that reflects the design after receiving those interactions would not provide context to the user.
Stakeholders may receive messages regarding the addition of comments, notes, or design changes to the design. For example, a stakeholder may receive a daily email describing all of the changes that happened in the previous day. As another example, a stakeholder may receive instant messages regarding changes as they are occurring. The messages can be pushed to particular stakeholders by the stakeholder adding the comment or note. For example, a user may add a note and select a stakeholder identifier from a drop down menu to push a message relating to their note to that stakeholder. The messages could also be subscribed to by particular stakeholders such that a stakeholder could configure which messages they would receive, the content of the messages, and how often the messages would be sent. For example, a security specialist could set their subscription to only send them messages that were flagged by stakeholders as requiring input from a security specialist. As another example, a project management user could set their subscription to send them an SMS message whenever a comment or note was marked urgent, and to route all other messages regarding comments and notes to their personal email.
Numerous features described above can be used to keep track of when and if various users have been read and by who. For example, whether or not a note has been read by a user could be tracked on a per user basis. This could happen explicitly by marking a comment or note read as the user making the mark has been identified by a user. The tracking could also be done implicitly be tracking whether a user has scrolled to a comment or have been expanded. For example, when the comments associated with a note are expanded by a user the system will track all of the comments as having been read by the user that expanded the note comments. This tracking information could also be sent to various stakeholders in the messages described above. In particular, in situations where the user or viewer that creates a note or comment can assign the note or comment to a particular stakeholder or particular class of stakeholders, that user or viewer can receive a message when the comment has been viewed by that stakeholder or class of stakeholders. The messages could include the particular identity of the stakeholder that read the comment. In these situations, only the particular stakeholder or class of stakeholders identified by the user or viewer when they created the note or comment may be able to mark a note or comment as read.
The informational content of the messages can vary. The message could just state that a comment or note was added or could include the entire contents of the note. Those contents may include a link to a rendering of the design or a file that was attached to the note or comment. The messages could identify the design and version in situations where stakeholders were collaborating on multiple designs or multiple versions of the same design. The messages could also identify the identity of the user or viewer that made the note or comment. The messages could also identify the stakeholders that were indicated as being responsible for addressing the note or comment. The message could also include a simple link to a rendering of the design in a player.
The content of the message can change based on the type of comment, note, or design change to which the note is directed. For example, a design change indicating that a version of the design was published or ready for review could trigger an email with a link to a rendering of the design in a player. Emails with links to a rendering of the design could be pushed automatically to all users associated with a project or individual users could be selected as recipients for the email. As another example, notes or comments that are marked with a “HIGH” priority could trigger the delivery of a message with the entire contents of the note or comment; while a note or comment that is marked with a “LOW” priority could trigger the delivery of a message indicating that a low priority comment or note was added.
Although embodiments of the invention have been discussed primarily with respect to specific embodiments thereof, other variations are possible. Various configurations of the described system may be used in place of, or in addition to, the configurations presented herein. Those skilled in the art will appreciate that the foregoing description is by way of example only, and is not intended to limit the invention.
Any of the methods described herein can be conducted through the use of a computer system 400 as shown in
While the specification has been described in detail with respect to specific embodiments of the invention, it will be appreciated that those skilled in the art, upon attaining an understanding of the foregoing, may readily conceive of alterations to, variations of, and equivalents to these embodiments. These and other modifications and variations to the present invention may be practiced by those skilled in the art, without departing from the spirit and scope of the present invention, which is more particularly set forth in the appended claims.
Claims
1. A computer-implemented method comprising:
- providing a graphical design environment to a first user using a processor, wherein the graphical design environment includes an interface that allows the first user to add a widget to a design;
- exporting the design from the graphical design environment;
- storing the design as an intermittent coded representation of the design in a markup language format, wherein the widget is exported with the design;
- rendering the design in a first design player using the intermitted coded representation of the design to create a rendering of the design for a second user;
- recording an interaction between the second user and the rendering of the design to create a set of instructions for rendering the design in accordance with the interaction;
- attaching the set of instructions to a note that is associated with the widget; and
- rendering the design in a second design player in accordance with the interaction using the set of instructions to create a playback for the first user.
2. The computer-implemented method of claim 1, further comprising:
- after the set of instructions is attached to the note, storing the set of instructions and the note in a common database with the widget;
- wherein the second design player is accessed from the graphical design environment; and
- wherein the first design player is a web browser.
3. The computer-implemented method of claim 2, wherein:
- the note is included in a script referenced by the intermittent coded representation of the design.
4. The computer-implemented method of claim 2, further comprising:
- rendering the note along with the design using an add-on to the web browser;
- wherein the note is rendered apart from the design as the design is rendered by the web browser.
5. The computer-implemented method of claim 1, further comprising:
- exchanging control of a simultaneous rendering of the design between the first user and the second user.
6. The computer-implemented method of claim 1, further comprising:
- storing the note and an indication of the widget the note is associated with;
- importing the design, the note, the indication, and the set of instructions into the graphical design environment, wherein the importing includes linking the note with the widget to create a linked note; and
- saving the linked note and the widget to a disk.
7. The computer-implemented method of claim 1, further comprising:
- displaying a note field in a note interface in the graphical design environment that accepts a text string from the first user, wherein the text string is subsequently stored as the note;
- wherein exporting the design from the graphical design environment includes exporting the note and storing the note as part of the intermittent coded representation of the design in the markup language format.
8. The computer-implemented method of claim 1, further comprising:
- displaying a discussion interface in the first design player, wherein the discussion interface includes a scrollbar, and wherein the scrollbar allows the second user to scroll through a set of notes that includes the note; and
- automatically adding a hyperlink to the note if the note is displayed in the discussion interface and the widget is not displayed in the first design player.
9. The computer-implemented method of claim 1, further comprising:
- displaying an icon in the first design player; and
- displaying a discussion interface in the first design player when the second user hovers a mouse cursor over the icon;
- wherein the discussion interface includes the note.
10. The computer-implemented method of claim 1, further comprising:
- sending a message via email to the first user when the second user changes a status of the note;
- wherein the message includes a file with the set of instructions.
11. A system comprising:
- a first workstation configured to instantiate a graphical design environment with an interface that allows a first user to add a widget to a design;
- an intermittent coded representation of the design that: (i) is exported from the design environment; and (ii) includes the widget;
- a second workstation that is configured to instantiate a first design player that renders the design for a second user using the intermittent coded representation; and
- a memory that stores: (i) a note associated with the widget; and (ii) a set of instructions for rendering the design in accordance with an interaction between the second user and the design;
- wherein the set of instructions is attached to the note in the memory; and
- wherein the first workstation: (i) has access to the memory; and (ii) is configured to instantiate a second design player that renders the design in accordance with the interaction using the set of instructions.
12. The system of claim 11, further comprising:
- a common database that stores the note and the widget, wherein the common database is configured to store the set of instructions after the instructions are attached to the note;
- wherein the second design player is a part of the graphical design environment; and
- wherein the first design player is a web browser.
13. The system of claim 12, further comprising:
- a script that is referenced by the intermittent coded representation of the design and that includes the note.
14. The system of claim 12, further comprising:
- an add-on to the web browser that is configured to render the note; and
- an unmodified portion of the web browser that is configured to render the design apart from the note.
15. The system of claim 11, further comprising:
- a routing system that is configured to exchange control of a simultaneous rendering of the design between the first user and the second user.
16. The system of claim 11, further comprising:
- a disk that is configured to save the note, an indication of the widget, the design, and the set of instructions after an importing process.
17. The system of claim 11, further comprising:
- a first discussion interface displayed in the first design player, wherein the first discussion interface includes a scrollbar, and wherein the scrollbar allows the second user to scroll through a set of notes that includes the note; and
- a processor that is configured to automatically add a hyperlink to the note if the note is displayed in the first discussion interface and the widget is not displayed;
- wherein the hyperlink provides a link to a rendering in which the widget appears.
18. The system of claim 11, further comprising:
- a first discussion interface displayed in the first design player when the first user hovers over an icon;
- wherein the icon is displayed in the first design player; and
- wherein the first discussion interface includes the note.
19. A system comprising:
- a means for providing a graphical design environment to a first user, wherein the graphical design environment includes an interface that allows the first user to add a widget to a design;
- a means for exporting the design from the graphical design environment and storing the design as an intermittent coded representation of the design in a markup language format, wherein the widget is exported with the design;
- a means for rendering the design using the intermitted coded representation of the design to create a rendering of the design for a second user; and
- a means, attached to a note associated with the widget, for rendering the design in accordance with a recorded interaction between the second user and the design.
20. The system of claim 19, further comprising:
- a means for storing the note and an indication of the widget; and
- a means for importing into the graphical design environment: (i) the design; (ii) the note; and (iii) the means for rendering the design in accordance with the recorded interaction.
Type: Application
Filed: Jun 8, 2015
Publication Date: Sep 24, 2015
Inventors: Victor Hsu (San Diego, CA), Martin Smith (San Diego, CA), Samir Hashem (San Diego, CA)
Application Number: 14/733,820