Skip to main content

Generating aesthetically pleasing colours that go well together

So the other day at work, my boss had another request for me, he wanted me to write some code that auto-generates a bunch of colours that go well together such that they could be used in a chart i.e something similar to what Google uses for their Google visualization API. So i wrote some code that generated decent enough colours and showed it to him, to which he responded, "is this what Google uses?" i was like no this is something we wrote, but he insisted that he wants exactly what Google uses and that is it. Now this was interesting as, Google provides a charting API for generating charts, but they don't exactly give access to the their colour generating algorithm. So to keep my boss happy, i came up with a little hack which solved our problem.

You see the way to do this would be to generate a mock chart using the Google Visualization API and then extract the colours out of the chart itself. You see the chart is an SVG object and with the use of JQuery ( I assume another JS library with JQuery like functionality can also be used ) we can read into the SVG object and get the colours from the html elements within it.

Problem

Get a set of colours that look good together.

Solution

This is a simple solution, what we are going to do is to create a pie chart using the Google visualization API and extract the colours from where the chart is drawn. An example of how a pie chart is drawn using google visualization tools can be found here.

fyi, this function relies on two includes, jquery and the Google jsapi i.e.

    <script type="text/javascript" src="https://www.google.com/jsapi"></script>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js" ></script>

Lets create a function that will accept 2 parameters, noOfColours and divId.

 function getGoodColours(noOfColours, divId)

The first step is to create some dummy data for that chart.

            var dataArray = [];
            var header = [];
            header.push("task");
            header.push("random");
            dataArray.push(header);
            for ( var j = 0; j < noOfColours; j++) {
                var data = [];
                data.push("" + j, 10);
                dataArray.push(data);
            }
Ok so now we have the data that we can use to initialise a data table and then draw a pie chart. Remember we already have the id of the div where we are going to draw the chart.

            var data = google.visualization.arrayToDataTable(dataArray);
            var chart = new google.visualization.PieChart(document.getElementById(divId));
            chart.draw(data);

At this point we have everything we need to start extracting the colours out of the chart, so lets just do that then.

            var colours = [];
            $("#"+divId).find("svg").find("g").find("rect").each(function() {
                var colour = $(this).attr("fill");
                if (colour.match("#ffffff") == null) {
                    colours.push(colour);
                }
            });
As you can see, this is really about using jquery going into the heart of the chart svg object and getting the important colours out of it.  Ok lastly dont forget to hide the chart drawn, in case you purpose of using this was just to generate the good colours.

            $("#"+divId).hide();
            return colours;

ohh and also the purpose of this function, i.e. return the colours extracted. 

Solution pitfalls

Now what is the downside of this solution? Well obviously this will only work as long as the structure of the SVG object is what it expects it to be.

Applications

I reckon this solution is useful to anyone with some charting needs, or for people who are stuck or lack the patience to to see what goes on well together through trail and error.

As usual the source code of the full example can be found here.


Comments

Popular posts from this blog

Upload to AWS S3 from Java API

In this post, you will see code samples for how to upload a file to AWS S3 bucket from a Java Spring Boot app. The code you will see here is from one of my open-source repositories on Github, called document-sharing. Problem Let’s say you are building a document sharing app where you allow your users to upload the file to a public cloud solution. Now, let’s say you are building the API for your app with Spring Boot and you are using AWS S3 as your public cloud solution. How would you do that? This blog post contains the code that can help you achieve that. Read more below,  Upload to AWS S3 bucket from Java Spring Boot app - My Day To-Do (mydaytodo.com)

App update, discovering Protractor(testing) and an Angularjs State machine

So for the last couple of weeks, I have not be able to update my blog or finish a couple of the posts that I started writing. Well, I have...been a bit busy, with some the following things,  Testing my app I have been using the app( iOS ) on my iPhone for the past couple of months now, which is both good and bad. The good thing is I can test it and the bad thing is, I can use it every day. Part of the reason, I started building this app is to have something that I can and like to use everyday and since I am already using it, the incentive to release it is not as high as if it were something that I could not use. Anyway I did make some good progress over the last couple of weeks, like  Delete the app from my iPhone and do a clean install: this did help me find a few simple bugs that would pop-up when the app is first installed GET AN APP ICON, FINALLY! this was a bit of a hurdle and I thanks to Fiverr  and fivercrazyguy , I finally have my app icon. The day job ...

Why can't I cancel a local notification in my iOS app?(in Swift)

Prelude I have mentioned the fact that I am working on my first iOS app in a number of my previous posts and as such I face a number of newbie/noob(?) problems. They are not really problems as much as they are simply things that I do not know, for e.g. the following, how do I get the day of the week? where is my string.replaceAll in Swift? knowing which local notification brought my app to foreground ? serving HTML content in an iOS app that works on iOS 7 and above Thankfully, I have managed to make at least one generic solution and contribute it to the community i.e. my open-source Xcode project template( HTML5StarterAppWithSwift ) which you can get from Github . So this post basically describes another very simple problem that I have found a solution to, but I do not fully understand why the problem was occurring in the first place. Introduction As I have mentioned in this post , my iOS app uses local notifications i.e. UILocalNotification   and i...