Skip to content

Instantly share code, notes, and snippets.

@BibMartin
Last active February 7, 2016 11:06
Show Gist options
  • Select an option

  • Save BibMartin/d55b2de09ed961723034 to your computer and use it in GitHub Desktop.

Select an option

Save BibMartin/d55b2de09ed961723034 to your computer and use it in GitHub Desktop.
HowTo embed python-nvd3 chart in folium
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<center><h1>How to embed `python-nvd3` chart into `folium`</h1></center>"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"We import the targeted libraries."
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"loaded nvd3 IPython extension\n",
"run nvd3.ipynb.initialize_javascript() to set up the notebook\n",
"help(nvd3.ipynb.initialize_javascript) for options\n"
]
}
],
"source": [
"import folium\n",
"from folium.element import *\n",
"from nvd3 import pieChart"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"We create a class that embeds a `python-nvd3` chart into a `folium.MacroElement`."
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"class Nvd3Chart(MacroElement):\n",
" \"\"\"TODO : docstring\"\"\"\n",
" def __init__(self, chart):\n",
" super(Nvd3Chart, self).__init__()\n",
" self._name = 'Nvd3Chart'\n",
" \n",
" self.chart = chart\n",
" self.chart.name = self.get_name()\n",
" self.chart.htmlcontent = None\n",
" self.chart.htmlheader = None\n",
" self.chart.container = None\n",
" self.chart.style = \"\"\n",
"\n",
" self._template = Template(u\"\"\"\n",
" {% macro header(this, kwargs) %}\n",
" {% if this.chart.buildhtmlheader() %}{% endif %}\n",
" {{this.chart.htmlheader}}\n",
" {% endmacro %}\n",
" {% macro html(this, kwargs) %}\n",
" {% if this.chart.buildcontent() %}{% endif %}\n",
" {{this.chart.htmlcontent}}\n",
" {% endmacro %}\n",
" \"\"\") # noqa"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Now, we create a chart (this is an example chart from `python-nvd3`'s doc)."
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"chart = pieChart(color_category='category20c', height=450, width=450)\n",
"xdata = [\"Orange\", \"Banana\", \"Pear\", \"Kiwi\", \"Apple\", \"Strawberry\", \"Pineapple\"]\n",
"ydata = [3, 4, 0, 1, 5, 7, 3]\n",
"extra_serie = {\"tooltip\": {\"y_start\": \"\", \"y_end\": \" cal\"}}\n",
"chart.add_serie(y=ydata, x=xdata, extra=extra_serie)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"And then we can use the chart into `folium`, as if it was a `folium` object."
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/html": [
"<iframe src=\"data:text/html;base64,
        <!DOCTYPE html>
        <head>
            
        
            <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
        
            
        
            <script src="https://cdnjs.cloudflare.com/ajax/libs/leaflet/0.7.3/leaflet.js"></script>
        
        
        
            
        
            <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
        
        
        
            
        
            <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/js/bootstrap.min.js"></script>
        
        
        
            
        
            <script src="https://rawgithub.com/lvoogdt/Leaflet.awesome-markers/2.0/develop/dist/leaflet.awesome-markers.js"></script>
        
        
        
            
        
            <script src="https://cdnjs.cloudflare.com/ajax/libs/leaflet.markercluster/0.4.0/leaflet.markercluster-src.js"></script>
        
        
        
            
        
            <script src="https://cdnjs.cloudflare.com/ajax/libs/leaflet.markercluster/0.4.0/leaflet.markercluster.js"></script>
        
        
        
            
        
            <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/leaflet/0.7.3/leaflet.css" />
        
        
        
            
        
            <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css" />
        
        
        
            
        
            <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap-theme.min.css" />
        
        
        
            
        
            <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.1.0/css/font-awesome.min.css" />
        
        
        
            
        
            <link rel="stylesheet" href="https://rawgit.com/lvoogdt/Leaflet.awesome-markers/2.0/develop/dist/leaflet.awesome-markers.css" />
        
        
        
            
        
            <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/leaflet.markercluster/0.4.0/MarkerCluster.Default.css" />
        
        
        
            
        
            <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/leaflet.markercluster/0.4.0/MarkerCluster.css" />
        
        
        
            
        
            <link rel="stylesheet" href="https://raw.githubusercontent.com/python-visualization/folium/master/folium/templates/leaflet.awesome.rotate.css" />
        
        
        
            
            <style>

            html, body {
                width: 100%;
                height: 100%;
                margin: 0;
                padding: 0;
                }

            #map {
                position:absolute;
                top:0;
                bottom:0;
                right:0;
                left:0;
                }
            </style>
            
        
            
            <style> #map_cf0df6c28d5243bc9907efbb35127881 {
                position : relative;
                width : 100.0%;
                height: 100.0%;
                left: 0.0%;
                top: 0.0%;
                }
            </style>
        
        
            
            <style> #div_095d44edaa6b4c4db37d972e20d5da1c {
                position : absolute;
                width : 45.0%;
                height: 90.0%;
                left: 2.5%;
                top: 5.0%;
            </style>
        
        
            
                
                <link href="https://cdnjs.cloudflare.com/ajax/libs/nvd3/1.7.0/nv.d3.min.css" rel="stylesheet" /><script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.5/d3.min.js"></script><script src="https://cdnjs.cloudflare.com/ajax/libs/nvd3/1.7.0/nv.d3.min.js"></script>
            
        
            
            <style> #div_9b98ba89d10c4c8c8b4359acf8ed6fb3 {
                position : absolute;
                width : 45.0%;
                height: 90.0%;
                left: 52.5%;
                top: 5.0%;
            </style>
        
        
        
        </head>
        <body>
            
        
            
            <div id="div_095d44edaa6b4c4db37d972e20d5da1c">
                
        
            
            <div class="folium-map" id="map_cf0df6c28d5243bc9907efbb35127881" ></div>
        
        
        
            </div>
        
        
            
            <div id="div_9b98ba89d10c4c8c8b4359acf8ed6fb3">
                
        
            
                
                
    <div id="nvd3_chart_c23968ea556241058b1feaf8665310c3"><svg style="width:450px;height:450px;"></svg></div>


    <script>



    data_nvd3_chart_c23968ea556241058b1feaf8665310c3=[{"values": [{"value": 3, "label": "Orange"}, {"value": 4, "label": "Banana"}, {"value": 0, "label": "Pear"}, {"value": 1, "label": "Kiwi"}, {"value": 5, "label": "Apple"}, {"value": 7, "label": "Strawberry"}, {"value": 3, "label": "Pineapple"}], "key": "Serie 1"}];

    nv.addGraph(function() {
        var chart = nv.models.pieChart();
        chart.margin({top: 30, right: 60, bottom: 20, left: 60});
        var datum = data_nvd3_chart_c23968ea556241058b1feaf8665310c3[0].values;

        chart.color(d3.scale.category20c().range());

    chart.tooltipContent(function(key, y, e, graph) {
          var x = String(key);
              var y =  String(y)  + ' cal';

              tooltip_str = '<center><b>'+x+'</b></center>' + y;
              return tooltip_str;
              });
        chart.showLabels(true);

            chart.donut(false);

    chart.showLegend(true);




        chart
            .x(function(d) { return d.label })
            .y(function(d) { return d.value });

        chart.width(450);

        chart.height(450);


            d3.select('#nvd3_chart_c23968ea556241058b1feaf8665310c3 svg')
            .datum(datum)
            .transition().duration(500)
            .attr('width', 450)
            .attr('height', 450)
            .call(chart);


        });



    </script>

            
        
        
            </div>
        
        
        
        </body>
        <script>
            
        
            

            var southWest = L.latLng(-90, -180);
            var northEast = L.latLng(90, 180);
            var bounds = L.latLngBounds(southWest, northEast);

            var map_cf0df6c28d5243bc9907efbb35127881 = L.map('map_cf0df6c28d5243bc9907efbb35127881', {
                                           center:[0,0],
                                           zoom: 1,
                                           maxBounds: bounds,
                                           layers: [],
                                           crs: L.CRS.EPSG3857
                                         });
        
        
            
            var tile_layer_b7e151bf050449c4b98d40fdfad9ddf9 = L.tileLayer(
                'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',
                {
                    maxZoom: 18,
                    minZoom: 1,
                    attribution: 'Data by <a href="http://openstreetmap.org">OpenStreetMap</a>, under <a href="http://www.openstreetmap.org/copyright">ODbL</a>.',
                    detectRetina: false
                    }
                ).addTo(map_cf0df6c28d5243bc9907efbb35127881);

        
        
        
        </script>
        \" width=\"100%\" height=\"500\"></iframe>"
],
"text/plain": [
"<folium.element.Figure at 0x7f6005cc2588>"
]
},
"execution_count": 4,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"f = Figure(width='100%', height=500)\n",
"\n",
"ax1 = f.add_subplot(1,2,1)\n",
"ax1.add_child(folium.Map())\n",
"\n",
"ax2 = f.add_subplot(1,2,2)\n",
"ax2.add_child(Nvd3Chart(chart))\n",
"\n",
"f"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"That's it."
]
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 3",
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.5.1"
}
},
"nbformat": 4,
"nbformat_minor": 0
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment