{ "cells": [ { "cell_type": "code", "execution_count": 1, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "0.7.0+14.gf4d024d.dirty\n" ] } ], "source": [ "import os\n", "import folium\n", "\n", "print(folium.__version__)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "# How to create Popups\n", "\n", "## Simple popups\n", "\n", "You can define your popup at the feature creation, but you can also overwrite them afterwards:" ] }, { "cell_type": "code", "execution_count": 2, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
" ], "text/plain": [ "" ] }, "execution_count": 2, "metadata": {}, "output_type": "execute_result" } ], "source": [ "m = folium.Map([45, 0], zoom_start=4)\n", "\n", "folium.Marker([45, -30], popup='inline implicit popup').add_to(m)\n", "\n", "folium.CircleMarker(\n", " location=[45, -10],\n", " radius=25,\n", " fill=True,\n", " popup=folium.Popup('inline explicit Popup')\n", ").add_to(m)\n", "\n", "ls = folium.PolyLine(\n", " locations=[[43, 7], [43, 13], [47, 13], [47, 7], [43, 7]],\n", " color='red'\n", ")\n", "\n", "ls.add_child(folium.Popup('outline Popup on Polyline'))\n", "ls.add_to(m)\n", "\n", "gj = folium.GeoJson(\n", " data={\n", " 'type': 'Polygon',\n", " 'coordinates': [[[27, 43], [33, 43], [33, 47], [27, 47]]]\n", " }\n", ")\n", "\n", "gj.add_child(folium.Popup('outline Popup on GeoJSON'))\n", "gj.add_to(m)\n", "\n", "m.save(os.path.join('results', 'simple_popups.html'))\n", "\n", "m" ] }, { "cell_type": "code", "execution_count": 3, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
" ], "text/plain": [ "" ] }, "execution_count": 3, "metadata": {}, "output_type": "execute_result" } ], "source": [ "m = folium.Map([45, 0], zoom_start=2)\n", "\n", "folium.Marker(\n", " location=[45, -10],\n", " popup=folium.Popup(\"Let's try quotes\", parse_html=True, max_width=100)\n", ").add_to(m)\n", "\n", "folium.Marker(\n", " location=[45, -30],\n", " popup=folium.Popup(u\"Ça c'est chouette\", parse_html=True, max_width='100%')\n", ").add_to(m)\n", "\n", "m" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Vega Popup\n", "\n", "You may know that it's possible to create awesome Vega charts with (or without) `vincent`. If you're willing to put one inside a popup, it's possible thanks to `folium.Vega`." ] }, { "cell_type": "code", "execution_count": 4, "metadata": {}, "outputs": [], "source": [ "import json\n", "import numpy as np\n", "import vincent\n", "\n", "scatter_points = {\n", " 'x': np.random.uniform(size=(100,)),\n", " 'y': np.random.uniform(size=(100,)),\n", "}\n", "\n", "# Let's create the vincent chart.\n", "scatter_chart = vincent.Scatter(scatter_points,\n", " iter_idx='x',\n", " width=600,\n", " height=300)\n", "\n", "# Let's convert it to JSON.\n", "scatter_json = scatter_chart.to_json()\n", "\n", "# Let's convert it to dict.\n", "scatter_dict = json.loads(scatter_json)" ] }, { "cell_type": "code", "execution_count": 5, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
" ], "text/plain": [ "" ] }, "execution_count": 5, "metadata": {}, "output_type": "execute_result" } ], "source": [ "m = folium.Map([43, -100], zoom_start=4)\n", "\n", "popup = folium.Popup()\n", "folium.Vega(scatter_chart, height=350, width=650).add_to(popup)\n", "folium.Marker([30, -120], popup=popup).add_to(m)\n", "\n", "# Let's create a Vega popup based on scatter_json.\n", "popup = folium.Popup(max_width=0)\n", "folium.Vega(scatter_json, height=350, width=650).add_to(popup)\n", "folium.Marker([30, -100], popup=popup).add_to(m)\n", "\n", "# Let's create a Vega popup based on scatter_dict.\n", "popup = folium.Popup(max_width=650)\n", "folium.Vega(scatter_dict, height=350, width=650).add_to(popup)\n", "folium.Marker([30, -80], popup=popup).add_to(m)\n", "\n", "m.save(os.path.join('results', 'vega_popups.html'))\n", "\n", "m" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Fancy HTML popup" ] }, { "cell_type": "code", "execution_count": 6, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
" ], "text/plain": [ "" ] }, "execution_count": 6, "metadata": {}, "output_type": "execute_result" } ], "source": [ "import branca\n", "\n", "\n", "m = folium.Map([43, -100], zoom_start=4)\n", "\n", "html = \"\"\"\n", "

This is a big popup


\n", " With a few lines of code...\n", "

\n", " \n", " from numpy import *
\n", " exp(-2*pi)\n", "
\n", "

\n", " \"\"\"\n", "\n", "\n", "folium.Marker([30, -100], popup=html).add_to(m)\n", "\n", "m.save(os.path.join('results', 'html_popups.html'))\n", "\n", "m" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "You can also put any HTML code inside of a Popup, thaks to the `IFrame` object." ] }, { "cell_type": "code", "execution_count": 7, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
" ], "text/plain": [ "" ] }, "execution_count": 7, "metadata": {}, "output_type": "execute_result" } ], "source": [ "m = folium.Map([43, -100], zoom_start=4)\n", "\n", "html = \"\"\"\n", "

This popup is an Iframe


\n", " With a few lines of code...\n", "

\n", " \n", " from numpy import *
\n", " exp(-2*pi)\n", "
\n", "

\n", " \"\"\"\n", "\n", "iframe = branca.element.IFrame(html=html, width=500, height=300)\n", "popup = folium.Popup(iframe, max_width=500)\n", "\n", "folium.Marker([30, -100], popup=popup).add_to(m)\n", "\n", "m.save(os.path.join('results', 'html_popups.html'))\n", "\n", "m" ] }, { "cell_type": "code", "execution_count": 8, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
" ], "text/plain": [ "" ] }, "execution_count": 8, "metadata": {}, "output_type": "execute_result" } ], "source": [ "import pandas as pd\n", "\n", "df = pd.DataFrame(data=[['apple', 'oranges'], ['other', 'stuff']], columns=['cats', 'dogs'])\n", "\n", "m = folium.Map([43, -100], zoom_start=4)\n", "\n", "html = df.to_html(classes='table table-striped table-hover table-condensed table-responsive')\n", "\n", "popup = folium.Popup(html)\n", "\n", "folium.Marker([30, -100], popup=popup).add_to(m)\n", "\n", "m.save(os.path.join('results', 'html_popups.html'))\n", "\n", "m" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Note that you can put another `Figure` into an `IFrame` ; this should let you do stange things..." ] }, { "cell_type": "code", "execution_count": 9, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
" ], "text/plain": [ "" ] }, "execution_count": 9, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# Let's create a Figure, with a map inside.\n", "f = branca.element.Figure()\n", "folium.Map([-25, 150], zoom_start=3).add_to(f)\n", "\n", "# Let's put the figure into an IFrame.\n", "iframe = branca.element.IFrame(width=500, height=300)\n", "f.add_to(iframe)\n", "\n", "# Let's put the IFrame in a Popup\n", "popup = folium.Popup(iframe, max_width=2650)\n", "\n", "# Let's create another map.\n", "m = folium.Map([43, -100], zoom_start=4)\n", "\n", "# Let's put the Popup on a marker, in the second map.\n", "folium.Marker([30, -100], popup=popup).add_to(m)\n", "\n", "# We get a map in a Popup. Not really useful, but powerful.\n", "m.save(os.path.join('results', 'map_popups.html'))\n", "\n", "m" ] } ], "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.7.1" } }, "nbformat": 4, "nbformat_minor": 1 }