Bubble Histogram

{
  "$schema": "https://vega.github.io/schema/vega-lite/v5.json",
  "usermeta": {
    "deneb": {
      "build": "1.4.0.0",
      "metaVersion": 1,
      "provider": "vegaLite",
      "providerVersion": "5.4.0"
    },
    "interactivity": {
      "tooltip": true,
      "contextMenu": true,
      "selection": false,
      "highlight": false,
      "dataPointLimit": 50
    },
    "information": {
      "name": "Bubble Histogram",
      "description": "[No Description Provided]",
      "author": "Kerry Kolosko",
      "uuid": "e5417a32-12c5-4d12-a5fc-6eefe46d2985",
      "generated": "2022-10-23T13:41:01.434Z",
      "previewImageBase64PNG": ""
    },
    "dataset": [
      {
        "key": "__0__",
        "name": "X",
        "description": "",
        "type": "text",
        "kind": "column"
      },
      {
        "key": "__1__",
        "name": "Y",
        "description": "",
        "type": "numeric",
        "kind": "column"
      },
      {
        "key": "__2__",
        "name": "Value",
        "description": "",
        "type": "numeric",
        "kind": "measure"
      }
    ]
  },
  "config": {
    "autosize": {
      "type": "fit",
      "contains": "padding"
    },
    "view": {"stroke": "transparent"}
  },
  "data": {"name": "dataset"},
  "spacing": 15,
  "bounds": "flush",
  "vconcat": [
    {
      "height": 60,
      "width": 350,
      "mark": {
        "type": "bar",
        "width": 15,
        "stroke": null,
        "cornerRadiusEnd": 2,
        "tooltip": true,
        "color": "#2999AA"
      },
      "encoding": {
        "x": {
          "field": "__0__",
          "axis": null
        },
        "y": {
          "field": "__2__",
          "aggregate": "mean",
          "axis": null
        }
      }
    },
    {
      "spacing": 15,
      "bounds": "flush",
      "hconcat": [
        {
          "height": 175,
          "width": 350,
          "mark": {
            "type": "circle",
            "opacity": 0.9,
            "stroke": "transparent",
            "tooltip": true
          },
          "encoding": {
            "y": {
              "field": "__1__",
              "type": "ordinal",
              "sort": "descending",
              "axis": {
                "domain": false,
                "ticks": false,
                "labels": true,
                "labelAngle": 0,
                "labelPadding": 5,
                "titlePadding": 15,
                "labelColor": "black",
                "titleColor": "black",
                "title": "Day →",
                "titleY": 170,
                "titleAlign": "left"
              }
            },
            "x": {
              "field": "__0__",
              "type": "ordinal",
              "axis": {
                "domain": false,
                "ticks": false,
                "labels": true,
                "labelColor": "black",
                "titleColor": "black",
                "titlePadding": 15,
                "title": "Hour →",
                "labelAngle": 0,
                "titleX": 10,
                "titleAlign": "left"
              }
            },
            "size": {
              "aggregate": "sum",
              "field": "__2__",
              "type": "quantitative"
            },
            "color": {
              "aggregate": "sum",
              "field": "__2__",
              "type": "quantitative",
              "scale": {
                "range": [
                  "#2999AA",
                  "orange"
                ]
              },
              "legend": null
            }
          }
        },
        {
          "height": 175,
          "width": 60,
          "mark": {
            "type": "bar",
            "height": 15,
            "stroke": null,
            "cornerRadiusEnd": 2,
            "tooltip": true,
            "color": "#2999AA"
          },
          "encoding": {
            "y": {
              "field": "__1__",
              "axis": null
            },
            "x": {
              "field": "__2__",
              "type": "quantitative",
              "aggregate": "mean",
              "axis": null
            }
          }
        }
      ]
    }
  ]
}

10 comments

  1. Hi Kerry,
    Really amazing chart here.
    I am starting out with Deneb but has been struggling a bit.
    How would you add data point labels to each of the bubbles in this chart? Any help would be greatly appreciated.

  2. Could you please help me to add the data labels at the end of each bar of the histogram?
    I tried reading all the examples and I failed every time I add the code in your template.

    Many thanks
    Manuel

  3. This is very insightful presentation Kerry,

    This first time i am using Deneb.

    Could you please help me with the below questions ?
    1) Do we need previewImageBase64PNG ?

    2) Which Image is that ?

    3) Not sure why top bar is not coming up in my chart .

    Seems like we need some more code using vconcat

  4. Hi Kerry,
    I like this visual very much. The only I struggle with is that the bars are not changing position if I change the order of days (ascending/descending). I hope this is easy to solve.
    Thank you in advance,
    Karlijn

  5. Hi, great work and works perfectly. I have one question. How can I set the background of the Canvas to transparent. Everything I tried didn’t work.

Leave a comment

Your email address will not be published. Required fields are marked *