The present disclosure relates to computerized systems and methods for rendering a user interface element and, more generally, the field of user interface design. By way of example, and without limitation, the present disclosure relates to computerized systems and methods for rendering an element of a user interface in a particular color based on characteristics of an image associated with the user interface.
The use of applications on electronic devices has grown significantly over the years. People now interact with applications on a variety of devices, such as personal computers, laptops, tablets, personal digital assistants (PDAs), personal organizers, mobile phones, smart-phones, and other devices. Developers of applications design interactive interfaces for the users of these applications to navigate through application content. With so many applications available today, developers have an incentive to make their applications attractive to users. One of the ways to do so is by making their application interfaces more aesthetically pleasing than those of other applications.
Embodiments of the present disclosure relate to computerized systems and methods for rendering user interface elements. In addition, embodiments of the present disclosure relate to solutions for presenting elements of a user interface in certain colors based on characteristics of images associated with the user interface.
In accordance with some embodiments of the present disclosure, computerized systems and methods are provided that identify characteristics of an image associated with a user interface. Once the characteristics are identified, they can be compared with one or more rules associated with a semantic name to identify a color that satisfies the rules. Once the color has been identified, an element of the user interface can be rendered in the identified color.
In accordance with some embodiments, there is provided a computer-implemented method for rendering a user interface element. The method comprises operations performed by one or more processors. The operations of the method include identifying characteristics of an image associated with a user interface, and identifying a semantic name associated with an element of the user interface. The method also includes comparing the identified characteristics with one or more rules associated with the semantic name to identify a color satisfying the one or more rules. The method further includes causing the element of the user interface to be rendered in the identified color when the color satisfies the rules.
Furthermore, in accordance with some embodiments, there is provided a computer-implemented system for rendering a user interface element. The system includes a memory device that stores instructions, and at least one processor that executes the instructions. The at least one processor executes the instructions to identify characteristics of an image associated with a user interface, and to identify a semantic name associated with an element of the user interface. The at least one processor also executes the instructions to compare the identified characteristics with one or more rules associated with the semantic name to identify a color satisfying the one or more rules. The at least one processor further executes the instructions to cause the element of the user interface to be rendered in the identified color when the color satisfies the rules.
Additionally, in accordance with some embodiments, there is provided a computer-implemented method for identifying a color for a user interface element. The method comprises operations performed by one or more processors. The operations of the method include identifying characteristics of an image associated with a user interface. The method also includes comparing the identified characteristics with each of a plurality of sets of one or more rules, each of the sets of rules being associated with a unique semantic name. The method further includes identifying, for each of the sets of rules, a color that satisfies the set of rules, and providing each identified color for presenting to an operator. The method still further includes receiving an indication of a request from the operator to associate one of the provided colors with a user interface element.
Still further, in accordance with some embodiments, there is provided a computer-implemented system for identifying a color for a user interface element. The system comprises a memory storing instructions, and at least one processor that executes the instructions. The at least one processor executes the instructions to identify characteristics of an image associated with a user interface. The at least one processor also executes the instructions to compare the identified characteristics with each of a plurality of sets of one or more rules, each of the sets of rules being associated with a unique semantic name. The at least one processor further executes the instructions to identify, for each of the sets of rules, a color that satisfies the set of rules, and to provide each identified color for presenting to an operator. The at least one processor still further executes the instructions to receive an indication of a request from the operator to associate one of the provided colors with a user interface element.
Before explaining example embodiments consistent with the present disclosure in detail, it is to be understood that the disclosure is not limited in its application to the details of constructions and to the arrangements set forth in the following description or illustrated in the drawings. The disclosure is capable of embodiments in addition to those described and is capable of being practiced and carried out in various ways. Also, it is to be understood that the phraseology and terminology employed herein, as well as in the abstract, are for the purpose of description and should not be regarded as limiting.
It is to be understood that both the foregoing general description and the following detailed description are explanatory only and are not restrictive of the claimed subject matter.
The accompanying drawings, which are incorporated in and constitute part of this specification, and together with the description, illustrate and serve to explain the principles of various example embodiments.
Reference will now be made in detail to the present embodiments of the disclosure, certain examples of which are illustrated in the accompanying drawings.
Embodiments of the present disclosure relate to computerized systems and methods for rendering user interface elements. Embodiments of the present disclosure include systems and methods that identify characteristics of an image associated with a user interface. Once the characteristics are identified, they can be compared with one or more rules associated with a semantic name to identify a color satisfying the one or more rules. A user interface element may then be automatically rendered in the identified color. Alternatively an operator may confirm or select the color so that a user interface element is rendered in the selected color.
In some embodiments, a developer of an application or operator may associate a semantic name with an element of a user interface of the application. In some embodiments, the semantic name may be representative of characteristics of a color that the developer is interested in associating with the user interface element. For example, a term “dark” may be used in a semantic name to indicate a color with low luminance, and a term “light” may be used in a semantic name to indicate a color with high luminance. As another example, a term “vibrant” could be used in a semantic name to indicate a color with high saturation, and a term “muted” could be used in a semantic name to indicate a color with low saturation. Terms representative of color characteristics may also be combined in a semantic name. For example, a “dark vibrant” semantic name may indicate a color that is low in luminance, but high in saturation.
Once a semantic name is selected for association with a user interface element, characteristics of colors in an image associated with the user interface may be analyzed and compared with one or more rules associated with the semantic name to identify a color that is likely to be desired by the developer. For example, the one or more rules associated with a “vibrant” semantic name may result in the selection of a color from the image with a high saturation.
In some embodiments, once a semantic name is associated with a user interface element, different images can be placed in the user interface, and the element may be automatically rendered in a color related to the image based on the rules associated with the semantic name. The different images may be placed in the user interface during the development of the application, or may be placed in the user interface based on a selection by a user. For example, a user of a music application may download a new music album, and an album cover of the music album may be received and displayed in the user interface based on the download. When the user makes a selection that causes the album cover to be displayed, the user interface element (e.g., a play button) may be rendered in a color related to a color in the image.
In some embodiments, an operator may select to receive a plurality of colors (e.g., a palette of colors) related to colors in an image. Based on the operator's selection, characteristics of colors in the image may be identified and compared with each of a plurality of sets of one or more rules, where each of the sets of rules is associated with a unique semantic name. For each of the sets of rules, a color that satisfies the set of rules may be identified and presented to the developer in the palette of colors. The operator may then select to associate one of the associated colors with the user interface element, so that the user interface element is rendered in that the selected color.
One or more advantages may be achieved in rendering elements of a user interface in colors that match, or complement, colors in an image associated with the user interface. For example, if a screen of a user interface includes an image with lot of red pixels, it may be aesthetically pleasing to render an element in the screen in a shade of red. It may also be desirable to change the color in which the element is rendered. For example, if the user makes a selection that causes the user interface to switch to a screen displaying a different image containing a lot of blue pixels, it may be aesthetically pleasing to render the same element in that screen in a shade of blue.
Making a user interface more aesthetically pleasing to users may be advantageous to developers. With so many applications on the market today, users have a wide variety of options from which to choose. All else being equal, users may choose an application that is more aesthetically pleasing, and the popularity of the application may increase. Moreover, developers of popular applications that include advertising may command higher prices for advertising spots in their applications than developers of less popular applications. However, developing a user interface that provides elements of the user interface in visually appealing colors presents challenges to developers. For example, a developer of an application may have to identify a color that is appealing for a user interface element through a process of trial and error. Moreover, once a developer has found a color for a particular user interface element, the developer may have to identify a different color for the element in a different screen. Another challenge is that many applications allow end users to include new images in a user interface, such as a new image of a music album cover in a music application. Developers of such applications may not be able to identify colors that match, or complement, colors in such a new image, because they will not know the colors of the new image when developing the application.
Embodiments of the present disclosure can address the challenges associated with rendering user interface elements in visually appealing colors. For example, embodiments of the present disclosure provide computerized systems and methods that may render a user interface element in a screen of a user interface in a color based on characteristics of colors in an image in the screen. An operator, such as a developer of an application, may simply select a semantic name representative of certain color attributes that the user developer desires for the element (e.g., light, dark, muted, vibrant), and one or more rules associated with the semantic name may be associated with the element. Once the rules are associated with the element, the element may be rendered in a particular color in a screen of the user interface based on colors in an image of the screen and the rules.
Embodiments of the present disclosure may also be used to increase efficiency of users performing certain tasks. Using embodiments of the present disclosure, placeholders may be rendered in colors representative of images before the images are loaded. This may allow a user loading a photo library to quickly identify whether a particular set of loading images may be the images for which the user is looking. For example, if a user is searching for photos from a camping trip, placeholders displayed in greens and earth tone colors may indicate to the user that the images to be loaded may be the images for which the user is searching.
Embodiments of the present disclosure may also provide an operator or user with an easy way to view a plurality of colors (e.g., a palette of colors) related to colors identified in an image. The plurality of colors may be identified by comparing characteristics of colors in the image with each of a plurality of sets of one or more rules, where each of the sets of rules is associated with a unique semantic name. For example, for an image of the statue of liberty, a sky blue color may satisfy a set of one or more rules associated with a “light vibrant” semantic name. In the same example, a dark green color may be satisfy a set of one or more rules associated with a “dark vibrant” semantic name. The operator may then select one of the identified colors for association with a user interface element.
An element of a user interface, as used herein, may include any element of a user interface. Such an element may include, for example, a button, icon, toolbar, control, link, folder, list, scrollbar, menu, menu item, image, video, animation, text, background, window, control, hyperlink, drop-down list, slider, border, mouse, cursor, pointer, placeholder for loading content, or any other portion of a user interface.
An image, as used herein, may include any type of image, such as a picture, background image, or graphic. The image could have any format, such as Joint Photographic Experts Group (JPEG), JPEG File Interchange Format (JFIF), JPEG 2000, Exchangeable Image File Format (EXIF), Tagged Image File Format (TIFF), raw image format, Graphics Interchange Format (GIF), Windows bitmap (BMP), Portable Network Graphics (PNG), portable pixmap file (PPM), portable graymap file (PGM), portable bitmap file (PBM), WebP, or any other image file format.
As used herein, rendering a user interface element in a color may refer to utilizing the color in any way to render the user interface element. For example, the color may be utilized in a translucent overlay of the element, combined with an image as a colored overlay of the image, etc. Moreover, portions of a user interface element may be displayed in the color, while other portions of the user interface element may be displayed in a different color.
In accordance with embodiments of the disclosure, one or more of the user interface elements illustrated in
Similarly, one or more of element A 120 and element B 130 may be associated with a semantic name. For example, element A 120 may be associated with a semantic name, such as “light vibrant.” Based on the example where image A is an image of the Statue of Liberty, element A 120 may be rendered in a sky blue color based on identifying sky blue as a color that satisfies the rules associated with the “light vibrant” semantic name. As another example, element B 130 may be associated with a semantic name, such as “light muted.” Based on the example where image A is an image of the Statue of Liberty, element B 130 may be rendered in a light green color based on identifying light green as a color that satisfies the rules associated with the “light muted” semantic name. Thus, in some embodiments, a plurality of user interface elements may be associated with different semantic names and rendered in different colors, each of which match, or compliment, colors in an image.
In step 210 of
In some embodiments, the image may be analyzed to identify the characteristics of the image. One or more conventional image analysis techniques may be used to identify the characteristics of the image, such as content or comparative image analysis techniques. Alternatively, the characteristics of the image may be received as data associated with the image, such as metadata associated with the image. The data associated with the image may be received from a local drive of a computer, such as computer system(s) 700, or from a different computer, such as server(s) 840, over network(s) 830.
In step 220 of
In step 230, the identified characteristics of the image are compared with the one or more rules associated with the semantic name. For example, a “dark” semantic name may be associated with one or more rules establishing that only colors having luminance values below a particular threshold value may be returned as “dark” colors. Accordingly, luminance values of the identified characteristics may be compared with the rules to determine which of the colors in the image are “dark” colors. Similarly, a “light vibrant” semantic name may be associated with one or more rules establishing that only colors having luminance values above a particular threshold value and having saturation values above a particular threshold value may be returned as “light vibrant” colors. Accordingly, luminance values and saturation values of the identified characteristics may be compared with the rules to determine which of the colors in the image are “light vibrant” colors.
A “placeholder” semantic name may be associated with one or more rules configured to identify a color that is most representative of the image. This color may correspond to a color that appears most frequently in the image, or to a color in the image that has a high visual strength for humans. For a placeholder element in a user interface, metadata about an image that is loading may be received in advance of the image, and the placeholder element may be rendered in a color based on characteristics of the image identified from the metadata.
In step 240, the element of the user interface may be rendered in the color that is identified as satisfying the one or more rules associated with the semantic name. For example, if the semantic name associated with the element is “dark vibrant,” the user interface element may be rendered in a color from the image, or a color representative of a color in the image, that satisfies the one or more rules.
In some embodiments, a semantic name may be associated with a user interface element of a user interface of an application by an operator or developer of the application. Once the semantic name is associated with the user interface element, the operator or developer may place different images in user interface screens that include the element, and the element may be automatically rendered based on colors in the image and the associated semantic name. Moreover, the element may be automatically rendered based on colors in images that an end user may add to the application.
The ability to automatically render user interface elements based on different images may be useful in applications where an end user is also adding new images to the user interface of the application. For example, if the application is a music player application, a user of the application may download a new music album. In such an example, an album cover may also be downloaded with the music album, and the album cover may be automatically displayed in a screen of the user interface when a user selects the album, along with a play button. Even though the album cover was not known to the developer of the application at the time the application was created, the user interface element (e.g., play button) may be rendered in a color that corresponds to its associated semantic name, and that matches, or complements the album cover.
In step 410, characteristics of an image may be identified. As previously noted with respect to method 200, characteristics of an image may include, for example, values related to one or more of a hue, intensity, radiance, luminance, luma, brightness, colorfulness, chroma, and saturation of colors in different pixels or regions of the image. In some embodiments, the characteristics of the image may include values of R, G, and B of a RGB color model for colors in different pixels or regions of the image. Similarly, the characteristics of the image may include values of Y, Cb, and Cr of a YCbCr color model for colors, values of Y, Pb, and Pr of a YPbPr color model for colors, HSL values, HSV values, HSI values, or any other values that can be used to represent colors of pixels or regions of the image. The identified characteristics of the image may also include a frequency with which a particular color appears in the image.
In some embodiments, the image may be analyzed to identify the characteristics of the image. Conventional image analysis techniques may be used to identify the characteristics of the image, such as content or comparative image analysis techniques. Alternatively, the characteristics of the image may be received as data associated with the image, such as metadata associated with the image. The data associated with the image may be received from a local drive of a computer, such as computer system(s) 700, or over from a different computer, such as server(s) 840, over network(s) 830.
In step 420, the identified characteristics of the image may be compared with each of a plurality of sets of one or more rules, wherein each of the sets of rules may be associated with a unique semantic name. In some embodiments, a set of semantic names may be pre-stored as representative of a palette of different types of colors in which an operator, such as a developer, may be interested. For example, the semantic names may include one or more of “vibrant,” “muted,” “dark,” “light,” “dark vibrant,” “dark muted,” “light vibrant,” and “light muted.” A “placeholder” semantic name could also be included. It should be appreciated that the above semantic names are provided only as examples, and that any semantic names may be used. In some embodiments, the semantic names are representative of one or more aspects of a color in which the operator may be interested.
The identified characteristics of the image may be representative of colors in pixels or regions of the image, and compared with sets one or more rules, where each of the sets of rules is associated with a unique semantic name. For example, a “dark” semantic name may be associated with one or more rules establishing that only colors having luminance values below a particular threshold value may be returned as “dark” colors. Accordingly, luminance values of the identified characteristics may be compared with the rules to determine which of the colors in the image are “dark” colors. Similarly, a “light vibrant” semantic name may be associated with one or more rules establishing that only colors having luminance values above a particular threshold value and having saturation values above a particular threshold value may be returned as “light vibrant” colors. Accordingly, luminance values and saturation values of the identified characteristics may be compared with the rules to determine which of the colors in the image are “light vibrant” colors.
A “placeholder” semantic name may be associated with one or more rules configured to identify a color that is most representative of the image. This color may correspond to a color that appears most frequently in the image, or to a color in the image that has a high visual strength for humans. For a placeholder element in a user interface, metadata about an image that is loading may be received in advance of the image, and the placeholder element may be rendered in a color based on characteristics of the image identified from the metadata.
In step 430, a color may be identified that satisfies the sets of rules for each of the plurality of sets of rules associated with the semantic names. For example, if the image is an image of the statue of liberty, a light green color may be identified for a “light muted” semantic name, a dark green color may be identified for a “dark vibrant” semantic name, a sky blue color may be identified for a “light vibrant” semantic name, etc. In some embodiments, colors may be identified for each of the semantic names in the plurality of semantic names. In some other embodiments, colors may be identified for only some of the semantic names in the plurality of semantic names.
In step 440, the identified colors may be presented to the operator or other user. In some embodiments, the identified colors may be presented as a palette of colors. In some embodiments, each of the identified colors may be presented in associated with its associated semantic name.
In step 450, an indication of a selection of an operator or user may be received. In some embodiments, the indication may indicate that the operator selected a color to associate with a user interface element. In some embodiments, the indication may indicate that the operator selected a semantic name to associate with a user interface element. For example, the operator may select to associate the “placeholder” semantic name with a space of a user interface that is a placeholder for loading content, such as an image. By doing so, the placeholder space of the user interface may be rendered in a color representative of the image before the image is loaded. This may be more visually appealing to end users than viewing a blank space while the image is loading.
Screen 520 of
In some embodiments, a color from the palette of colors may be selected for associating with one or more elements of a user interface. For example, an operator or application developer may select a color from the palette of colors for associating with one or more elements of a user interface of an application. In some embodiments, the operator or developer may select a semantic name from the list of semantic names to associate the semantic name with one or more elements of a user interface.
In step 610, colors may be identified in an image. In some embodiments, colors in each pixel, block, or region of the image may be identified. In some embodiments, each of the identified colors may be stored in a map, list, or table in association with the pixel, block, or region of the image in which it was identified. In some embodiments, the colors may be stored as characteristics of the colors. For example, colors may be represented in values of hue, intensity, radiance, luminance, luma, brightness, colorfulness, chroma, and/or saturation. In some embodiments, colors may be represented as a combination of values corresponding to a color model, such as values of R, G, and B of a RGB color model, values of Y, Cb, and Cr of a YCbCr color model, values of Y, Pb, and Pr of a YPbPr color model, HSL values, HSV values, HSI values, or any other values of any other color models.
In some embodiments, the image may include a large number of different colors. To reduce the number of colors that need to be handled, method 600 may force the colors to a certain limited number of colors. For example, a color blue that is a slightly lighter shade than another color of blue in the image may be treated as the same color blue. Method 600 may use a known image analysis technique, such as adaptive quantization, to limit the number of colors in the image to a certain number of colors (e.g., 12-16 colors). Method 600 may then count the number of pixels, blocks, or regions of the image in which a particular color appears, and, in step 620, may store the colors in a an ordered list with the colors sorted from those appearing most frequently in the image to those appearing least frequently in the image.
In step 630, the color appearing most frequently in the ordered list may be compared with one or more rules associated with a semantic name. For example, the semantic name may be a semantic name associated with a user interface element, such as in the example of method 200 of
In one example, values of R, G, and B of a color may be compared with one or more rules to determine whether a color qualifies as a color for the semantic name. For example, a bright orange color with an R value of 217, a G value of 118, and a B value of 33 may satisfy one or more rules for “dark vibrant” color. In a further example, values for hue, intensity, radiance, luminance, luma, brightness, colorfulness, chroma, saturation, R, G, and B of a RGB color model, Y, Cb, and Cr of a YCbCr color model, Y, Pb, Pr of a YPbPr color model, HSL, HSV, and/or HSI may be converted to a different color model before performing the comparison. For example, RGB values may be converted to HSL values and compared with one or more rules for HSL values associated with a semantic name.
If the most frequently appearing color does not satisfy the one or more rules associated with the semantic name, method 600 may compare the second most frequently occurring color (e.g., the next one down the ordered list) with the one or more rules to determine whether the second most frequently occurring color satisfies the rules. Method 600 may continue in this fashion until a color is identified that satisfies the one or more rules associated with the semantic name.
It should be appreciated that the above method is merely one example of how characteristics may be identified and compared with one or more rules associated with a semantic name to identify a color that satisfies the rules. Any other method could be used for identifying the color, and any other characteristics of an image could be compared with any other rules for identifying the color. In some embodiments, a frequency with which a color appears in an image may be only one factor used in sorting the ordered list. For example, a combination of factors could be used in sorting the ordered list.
In some embodiments, another factor that could be used in sorting the ordered list are values related to a visual strength of the colors. For example, some colors have a greater visual strength to humans than others. Such a color may appear to a human as being more dominant in an image even if the number of pixels of that color is relatively small compared to those of another color. An example of such a color may be a bright red color. In some embodiments, visual strength values may be associated with each of the colors, and the colors may be sorted in the ordered list based on a weighted combination of a visual strength of the colors and the frequency with which the colors appear in the image. In some embodiments, certain colors may be weighted less than other colors, so that they appear lower in the ordered list than the frequency of the colors appearance in the image would otherwise place them. For example, colors resembling human skin tone may be considered to be undesirable for user interface elements, and may be weighted so as to be placed toward the bottom of the ordered list, or removed from the ordered list entirely.
In some embodiments, none of the colors may satisfy the rules associated with a particular semantic name. For example, if an operator has specified a “dark vibrant” semantic name for a particular user interface element, it is possible that none of the colors in the image satisfy the rules associated with the “dark vibrant” semantic name. In such a scenario, a color could be identified based on a different color identified in the ordered list. For example, a “vibrant” color (e.g., sky blue) could be identified in the ordered list, and a “dark vibrant” color (e.g., ocean blue) could be calculated based off of the “vibrant” color.
Although the above example may relate to identifying a color that satisfies the one or more rules associated with a semantic name, method 600 may be used to identify colors that satisfy sets of rules for each of a plurality of sets of rules, where each of the sets of rules corresponds to a semantic name. For example, a color appearing at the top of the ordered list may be compared with each of the sets of rules to determine whether the color satisfies any of the sets of rules. In so doing, method 600 may traverse the ordered list and identify a color that satisfies the sets of rules for each of a plurality of sets of rules associated with semantic names.
As indicated throughout this disclosure, semantic names representative of aspects of colors may be associated with elements of a user interface, so that the elements are rendered in particular colors based on images associated with the user interface. Once a semantic name has been associated with an element of the user interface, rules may be defined or provided for rendering other elements of the user interface based on the semantic name associated with the element. For example, a button element may be overlaid with a text element. One or more rules may be associated with the text element to render the text in a color that contrasts with the semantic name of the button element. For example, if a button is associated with a “dark vibrant” semantic name, and a text element overlays the button, the text element may be rendered in a light color based on one or more rules associated with the text element that cause the text element to be rendered in a color in contrast to the button. These types of rules may be referred to as related color rules, and may include rules for rendering elements in colors that contrast, or complement, other elements in the user interface.
As shown in
A computing device 780 may include one or more storage devices configured to store data and/or software instructions used by processor(s) 710 to perform operations consistent with disclosed embodiments. For example, a computing device 780 may include main memory 730 configured to store one or more software programs that, when executed by processor(s) 710, cause processor(s) 710 to perform functions or operations consistent with disclosed embodiments. In some embodiments, software instructions for performing operations consistent with disclosed embodiments may be provided in an application programming interface (API) that is made available to developers of applications. For example, the software instructions may be included as part of an API available to developers of applications for certain computing platforms. The API may be downloaded by a developer, and instructions in the API may be executed by processor(s) 710 to perform functions or operations consistent with disclosed embodiments.
By way of example, main memory 730 may include NOR or NAND flash memory devices, read only memory (ROM) devices, random access memory (RAM) devices, etc. A computing device 780 may also include on or more storage mediums 740. By way of example, storage medium(s) 740 may include hard drives, solid state drives, tape drives, redundant array of independent disks (RAID) arrays, etc. Although
Storage medium(s) 740 may be configured to store data, and may store data received from one or more of server(s) 840 or client device(s) 820. The data may take or represent various content or information forms, such as content, metadata, documents, textual content, image files, video files, markup information (e.g., hypertext markup language (HTML) information, extensible markup language (XML) information), software applications, instructions, and/or any other type of information that may be with a user interface of an application.
A computing device 780 may also include one or more displays 750 for user interfaces, displaying data, and information. Display(s) 750 may be implemented using one or more display panels, which may include, for example, one or more cathode ray tube (CRT) displays, liquid crystal displays (LCDs), plasma displays, light emitting diode (LED) displays, touch screen type displays, projector displays (e.g., images projected on a screen or surface, holographic images, etc.), organic light emitting diode (OLED) displays, field emission displays (FEDs), active matrix displays, vacuum fluorescent (VFR) displays, 3-dimensional displays, electronic paper (e-ink) displays, microdisplays, or any combination of the above types of displays.
A computing device 780 may further include one or more communications interfaces 760. Communication interface(s) 760 may allow software and/or data to be transferred between server(s) 840 and client device(s) 820. Examples of communications interface(s) 760 may include modems, network interface cards (e.g., Ethernet card), communications ports, personal computer memory card international association (PCMCIA) slots and cards, antennas, etc. Communication interface(s) 760 may transfer software and/or data in the form of signals, which may be electronic, electromagnetic, optical, and/or other types of signals. The signals may be provided to/from communications interface(s) 760 via a communications path (e.g., network(s) 830), which may be implemented using wired, wireless, cable, fiber optic, radio frequency (RF), and/or other communications channels.
The disclosed embodiments are not limited to separate programs or computers configured to perform dedicated tasks. For example, a server 840 may include a main memory 730 that stores a single program or multiple programs and may additionally execute one or more programs located remotely from server 840. Similarly, a client device 820 may execute one or more remotely stored programs instead of, or in addition to, programs stored on client device 820. In some example embodiments, a server 840 may be capable of accessing separate server(s) and/or computing devices that generate, maintain, and provide web sites.
As shown in
Computing environment 800 may also include one or more server(s) 840. By way of example, server(s) 840 could include any combination of one or more of web servers, databases, mainframe computers, general-purpose computers, personal computers, or other types of computing devices. In some embodiments, one or more of server(s) 840 may be configured to host a web page, implement a search engine, index information, store information, and/or retrieve information. In some embodiments, a server 840 may be a standalone computing system or apparatus, or it may be part of a larger system. For example, server(s) 840 may represent distributed servers that are remotely located and communicate over a communications network, or over a dedicated network, such as a local area network (LAN). Server(s) 840 may include one or more back-end servers for carrying out one or more aspects of the present disclosure.
Server(s) 840 may be implemented as a server system comprising a plurality of servers, or a server farm comprising a load balancing system and a plurality of servers. In some embodiments, a server 840 may be implemented with hardware devices and/or software applications running thereon. A server 840 may communicate with client device(s) 820 over network(s) 830. For example, a server 840 may communicate by transmitting data to and/or receiving data from client device(s) 820. In some embodiments, one or more of server(s) 840 may be implemented using a computer system, such as computer system 700 of
In some embodiments, server(s) 840 may store image files and/or metadata associated with image files. User interfaces of applications running on client device(s) 820 may download the image files and/or metadata, and may identify characteristics of the images in the image files by analyzing the image files or the metadata. In some embodiments, server(s) 840 may identify characteristics of images stored at server(s) 840, may compare the identified characteristics with sets of rules associated with semantic names, and/or may identify colors from images that correspond to semantic names, and may store this information as metadata at server(s) 840. By doing so, a client device 820 may simply download the metadata to identify a color from the image that corresponds to the semantic name. That is, the processing of the image data and its comparison with the rules will be performed by server(s) 840, so that client device(s) 820 do not have to perform these steps themselves. Moreover, themes for associating semantic names with various user interface elements may be stored at server(s) 840, and may be downloaded and applied to applications by developers, so that they do not have decide which semantic names to associate with elements of a user interface.
Computing environment 800 may still further include one or more networks 830. Network(s) 830 may connect server(s) 840 with client device(s) 820. network(s) 830 may provide for the exchange of information, such as queries for information and results, between client device(s) 820 and server(s) 840. Network(s) 830 may include one or more types of networks interconnecting client device(s) 820 and server(s) 840.
Network(s) 830 may include one or more wide area networks (WANs), metropolitan area networks (MANs), local area networks (LANs), personal area networks (PANs), or any combination of these networks. Network(s) 830 may include one network type, or a combination of a variety of different network types, including Internet, intranet, Ethernet, twisted-pair, coaxial cable, fiber optic, cellular, satellite, IEEE 802.11, terrestrial, Bluetooth, infrared, wireless universal serial bus (wireless USB), and/or other types of wired or wireless networks.
It should be appreciated that there are a variety of uses for the embodiments and techniques disclosed herein. For example, in addition to the uses previously described, the embodiments and techniques disclosed herein may be used to render colors in placeholder spaces of a user interface while waiting for content, such as an image, to load. The embodiments and techniques disclosed herein may also be used to set neighboring color fields in a user interface. The embodiments and techniques disclosed herein may further be used to create image fade in or fade out effects. The embodiments and techniques disclosed herein may still further be used to render duotone images. The embodiments and techniques disclosed herein may also be used to render different colors for different types of loading content, to indicate the type of content about to load.
While illustrative embodiments have been described herein, the scope includes any and all embodiments having equivalent elements, modifications, omissions, combinations (e.g., of aspects across various embodiments), adaptations and/or alterations based on the present disclosure. The elements in the claims are to be interpreted broadly based on the language employed in the claims and not limited to examples described in the present specification or during the prosecution of the application, which examples are to be construed as non-exclusive. Further, the steps of the disclosed methods can be modified in any manner, including reordering steps and/or inserting or deleting steps.
The many features and advantages of the disclosure are apparent from the detailed specification, and thus, it is intended that the appended claims cover all systems and methods, which fall within the true spirit and scope of the disclosure. As used herein, the indefinite articles “a” and “an” mean “one or more” in open-ended claims containing the transitional phrase “comprising,” “including,” and/or “having.” Further, since numerous modifications and variations will readily occur to those skilled in the art, it is not desired to limit the disclosure to the exact construction and operation illustrated and described, and accordingly, all suitable modifications and equivalents may be resorted to, falling within the scope of the disclosure.
This application claims the benefit of U.S. Provisional Patent Application No. 62/016,612, filed Jun. 24, 2014, the contents of which are hereby incorporated by reference in their entirety.
Number | Date | Country | |
---|---|---|---|
62016612 | Jun 2014 | US |