Last active
February 7, 2016 11:06
-
-
Save BibMartin/d55b2de09ed961723034 to your computer and use it in GitHub Desktop.
HowTo embed python-nvd3 chart in folium
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| { | |
| "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