pannellum
Pannellum is a lightweight, free, and open source panorama viewer for the web.
Top Related Projects
A 360° media viewer for the modern web.
Javascript panorama viewer based on Three.js
An open-source, web-based viewer for zoomable images, implemented in pure JavaScript.
:a: Web framework for building virtual reality experiences.
Quick Overview
Pannellum is an open-source, lightweight, and customizable panorama viewer for the web. It allows users to embed 360-degree panoramic images and virtual tours into websites using HTML5 and WebGL. Pannellum supports various types of panoramas, including equirectangular, cubic, and multi-resolution.
Pros
- Easy to integrate into existing web projects
- Supports multiple panorama formats and types
- Highly customizable with a wide range of configuration options
- Mobile-friendly and responsive design
Cons
- Limited documentation for advanced features
- Performance may be affected on older devices or browsers
- Lacks built-in support for some advanced features like hotspots with custom HTML content
- Requires JavaScript to be enabled in the browser
Code Examples
- Basic panorama viewer:
<div id="panorama"></div>
<script>
pannellum.viewer('panorama', {
"type": "equirectangular",
"panorama": "path/to/image.jpg"
});
</script>
- Customized viewer with controls and autorotate:
<div id="panorama"></div>
<script>
pannellum.viewer('panorama', {
"type": "equirectangular",
"panorama": "path/to/image.jpg",
"autoRotate": -2,
"autoLoad": true,
"showControls": false
});
</script>
- Adding hotspots to the panorama:
<div id="panorama"></div>
<script>
pannellum.viewer('panorama', {
"type": "equirectangular",
"panorama": "path/to/image.jpg",
"hotSpots": [
{
"pitch": 14.1,
"yaw": 1.5,
"type": "info",
"text": "Baltimore Museum of Art"
},
{
"pitch": -9.4,
"yaw": 222.6,
"type": "info",
"text": "Art Museum Drive"
}
]
});
</script>
Getting Started
- Include Pannellum's CSS and JavaScript files in your HTML:
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/pannellum@2.5.6/build/pannellum.css"/>
<script type="text/javascript" src="https://cdn.jsdelivr.net/npm/pannellum@2.5.6/build/pannellum.js"></script>
- Create a container element for the panorama:
<div id="panorama"></div>
- Initialize the viewer with JavaScript:
<script>
pannellum.viewer('panorama', {
"type": "equirectangular",
"panorama": "path/to/your/image.jpg"
});
</script>
Replace "path/to/your/image.jpg" with the actual path to your panoramic image. Adjust the configuration options as needed for your specific use case.
Competitor Comparisons
A 360° media viewer for the modern web.
Pros of Marzipano
- More comprehensive documentation and examples
- Better support for mobile devices and touch interactions
- Advanced features like multi-resolution imagery and hotspots
Cons of Marzipano
- Steeper learning curve due to more complex API
- Larger file size and potentially slower load times
- Less straightforward integration with existing web projects
Code Comparison
Pannellum:
pannellum.viewer('panorama', {
"type": "equirectangular",
"panorama": "path/to/image.jpg"
});
Marzipano:
var viewer = new Marzipano.Viewer(document.getElementById('pano'));
var source = Marzipano.ImageUrlSource.fromString("path/to/image.jpg");
var geometry = new Marzipano.EquirectGeometry([{ width: 4000 }]);
var view = new Marzipano.RectilinearView();
var scene = viewer.createScene({source: source, geometry: geometry, view: view});
scene.switchTo();
Both Pannellum and Marzipano are powerful libraries for creating 360° panoramas, but they cater to different needs. Pannellum is simpler to use and integrate, making it ideal for quick implementations. Marzipano offers more advanced features and better performance on mobile devices, but requires more setup and understanding of its API. The choice between the two depends on the specific requirements of your project and your familiarity with 360° panorama concepts.
Javascript panorama viewer based on Three.js
Pros of Panolens.js
- Built on Three.js, offering more advanced 3D rendering capabilities
- Supports both equirectangular and cubemap panoramas
- Includes features like video panoramas and Google Street View integration
Cons of Panolens.js
- Larger file size due to Three.js dependency
- Steeper learning curve for developers not familiar with Three.js
- Less extensive documentation compared to Pannellum
Code Comparison
Pannellum:
pannellum.viewer('panorama', {
"type": "equirectangular",
"panorama": "path/to/image.jpg"
});
Panolens.js:
const panorama = new PANOLENS.ImagePanorama('path/to/image.jpg');
const viewer = new PANOLENS.Viewer();
viewer.add(panorama);
Both libraries offer straightforward ways to create panoramic viewers, but Panolens.js requires more setup due to its Three.js foundation. Pannellum's approach is more concise for simple panoramas, while Panolens.js provides more flexibility for complex 3D scenes.
Pannellum is better suited for developers seeking a lightweight, easy-to-use panorama viewer with extensive documentation. Panolens.js is ideal for those who need advanced 3D capabilities and are comfortable working with Three.js.
An open-source, web-based viewer for zoomable images, implemented in pure JavaScript.
Pros of OpenSeadragon
- More versatile, supporting various image formats and deep zoom capabilities
- Extensive API and plugin system for customization
- Larger community and more frequent updates
Cons of OpenSeadragon
- Steeper learning curve due to more complex features
- Larger file size and potentially higher resource usage
- Not specifically designed for panoramic images
Code Comparison
OpenSeadragon:
var viewer = OpenSeadragon({
id: "openseadragon1",
prefixUrl: "/openseadragon/images/",
tileSources: "/path/to/image.dzi"
});
Pannellum:
pannellum.viewer('panorama', {
"type": "equirectangular",
"panorama": "/path/to/image.jpg"
});
OpenSeadragon focuses on deep zoom functionality for various image types, while Pannellum is specifically designed for panoramic images. OpenSeadragon offers more flexibility and features but may be overkill for simple panorama viewing. Pannellum provides a more straightforward implementation for panoramic images but lacks the extensive customization options of OpenSeadragon.
:a: Web framework for building virtual reality experiences.
Pros of A-Frame
- More comprehensive VR/AR framework with a wider range of features
- Active community and extensive documentation
- Supports a variety of VR headsets and devices
Cons of A-Frame
- Steeper learning curve for beginners
- Potentially heavier and slower for simple panorama viewing
- May be overkill for projects that only require basic 360° image display
Code Comparison
Pannellum (simple panorama viewer):
pannellum.viewer('panorama', {
"type": "equirectangular",
"panorama": "path/to/image.jpg"
});
A-Frame (360° image viewer):
<a-scene>
<a-sky src="path/to/image.jpg"></a-sky>
</a-scene>
Summary
Pannellum is a lightweight, specialized panorama viewer, while A-Frame is a full-featured VR/AR framework. Pannellum is easier to implement for simple panorama projects, whereas A-Frame offers more flexibility and features for complex VR/AR experiences. The choice between the two depends on the project's specific requirements and the developer's familiarity with VR/AR development.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
Pannellum
About
Pannellum is a lightweight, free, and open source panorama viewer for the web. Built using HTML5, CSS3, JavaScript, and WebGL, it is plug-in free. It can be deployed easily as a single file, just 21kB gzipped, and then embedded into pages as an <iframe>
. A configuration utility is included to generate the required code for embedding. An API is included for more advanced integrations.
Getting started
Hosted examples
A set of examples that demonstrate the viewer's various functionality is hosted on pannellum.org. This is the best place to start if you want an overview of Pannellum's functionality. They also provide helpful starting points for creating custom configurations.
Simple tutorial and configuration utility
If you are just looking to display a single panorama without any advanced functionality, the steps for doing so are covered on the simple tutorial page. Said page also includes a utility for easily creating the necessary Pannellum configuration.
Local testing and self-hosting
If you would like to locally test or self-host Pannellum, continue to the How to use section below.
How to use
- Upload
build/pannellum.htm
and a full equirectangular panorama to a web server or run a development web server locally.- Due to browser security restrictions, a web server must be used locally as well. With Python 3, one can use
python3 -m http.server
, but any other web server should also work.
- Due to browser security restrictions, a web server must be used locally as well. With Python 3, one can use
- Use the included multi-resolution generator (
utils/multires/generate.py
), the configuration tool (utils/config/configuration.htm
), or create a configuration from scratch or based on an example. - Insert the generated
<iframe>
code into a page, or create a more advanced configuration with JSON or the API.
Configuration parameters are documented in the doc/json-config-parameters.md
file, which is also available at pannellum.org/documentation/reference/. API methods are documented inline with JSDoc comments, and generated documentation is available at pannellum.org/documentation/api/. For the standalone viewer, configuration parameters are preferably specified using a location hash instead of a location search query, e.g., pannellum.htm#panorama=...
instead of pannellum.htm?panorama=...
, since this does not unnecessarily send the query parameters to the server.
Using a minified copy
For final deployment, it is recommended that one use a minified copy of Pannellum instead of using the source files in src
directly. The easiest method is to download the most recent release and use the pre-built copy of either pannellum.htm
or pannellum.js
& pannellum.css
. If you wish to make changes to Pannellum or use the latest development copy of the code, follow the instructions in the Building section below to create build/pannellum.htm
, build/pannellum.js
, and build/pannellum.css
.
Using generate.py
to create multires panoramas
To be able to create multiresolution panoramas, you need to have the nona
program installed, which is available as part of Hugin, as well as Python 3 with the Pillow and NumPy packages. The pyshtools Python package is also recommended. Then, run
python3 generate.py pano_image.jpg
in the utils/multires
directory. This will generate all the image tiles and the config.json
file in the ./output
folder by default. For this to work, nona
needs to be on the system path; otherwise, the location of nona
can be specified using the -n
flag. On a Unix-like platform, with nona
already on the system path use:
$ cd utils/multires
$ python3 generate.py pano_image.jpg
where pano_image.jpg
is the filename of your equirectangular panorama. If nona
is not on the system path, use:
$ cd utils/multires
$ python3 generate.py -n /path/to/nona pano_image.jpg
For a complete list of options, run:
$ python3 generate.py --help
To view the generated configuration, run:
$ cd ../..
$ python3 -m http.server
This goes back to the root directory of the repository and starts a local development web server. Then open http://localhost:8000/src/standalone/pannellum.htm#config=../../utils/multires/output/config.json in your web browser of choice.
Bundled examples
Examples using both the minified version and the version in the src
directory are included in the examples
directory. These can be viewed by starting a local web server in the root of the repository, e.g., by running:
$ python3 -m http.server
in the directory containing this readme file, and then navigating to the hosted HTML files using a web browser; note that the examples use files from the src
directory, so the web server must be started from the repository root, not the examples
directory. For the example-minified.htm
example to work, a minified copy of Pannellum must first be built; see the Building section below for details.
Additional examples are available at pannellum.org.
Browser Compatibility
Since Pannellum is built with web standards, it requires a modern browser to function.
Full support (with appropriate graphics drivers):
- Firefox 23+
- Chrome 24+
- Safari 8+
- Internet Explorer 11+
- Edge
The support list is based on feature support. As only recent browsers are tested, there may be regressions in older browsers.
Not officially supported:
Mobile / app / web frameworks are not officially supported. They may work, but they're not tested and are not the targeted platform.
Translations
All user-facing strings can be changed using the strings
configuration parameter. There exists a third-party respository of user-contributed translations that can be used with this configuration option.
Building
The utils
folder contains the required build tools, with the exception of Python 3.2+ and Java installations. To build a minified version of Pannellum, run either build.sh
or build.bat
depending on your platform. On a Unix-like platform:
$ cd utils/build
$ ./build.sh
If successful, this should create build/pannellum.htm
, build/pannellum.js
, and build/pannellum.css
, relative to the root directory of the repository.
Tests
A minimal Selenium-based test suite is located in the tests
directory. The tests can be executed by running:
python3 run_tests.py
A Selenium-driven web browser (with a Chrome driver, by default) is created, and screenshots are generated and compared against previously generated ones in tests. For example, to regenerate the screenshots one can run:
$ python3 tests/run_tests.py --create-ref
And to simply run the tests to compare to, eliminate that argument. By default, a random port is selected, along with other arguments. One can see usage via:
$ python tests/run_tests.py --help
Continuous integration tests are run via Travis CI. Running the tests locally requires Python 3, the Selenium Python bindings, Pillow, NumPy, and either Firefox & geckodriver or Chrome & ChromeDriver.
Seeking support
If you wish to ask a question or report a bug, please open an issue at github.com/mpetroff/pannellum. See the Contributing section below for more details.
Contributing
Development takes place at github.com/mpetroff/pannellum. Issues should be opened to report bugs or suggest improvements (or ask questions), and pull requests are welcome. Please make an attempt to write in grammatically-correct English on the issue tracker; using the results of machine translation is acceptable if one in not fluent in the language, and attempts to work past language barriers will be made. When reporting a bug, please try to include a minimum reproducible example (or at least some sort of example). When proposing changes, please try to match the existing code style, e.g., four space indentation and JSHint validation. If your pull request adds an additional configuration parameter, please document it in doc/json-config-parameters.md
. Pull requests should preferably be created from feature branches.
License
Pannellum is distributed under the MIT License. For more information, read the file COPYING
or peruse the license online.
In the past, parts of Pannellum were based on three.js r40, which is licensed under the MIT License.
The panoramic image provided with the examples is licensed under the Creative Commons Attribution-ShareAlike 3.0 Unported License.
Credits
- Matthew Petroff, Original Author
- three.js r40, Former Underlying Framework
If used as part of academic research, please cite:
Petroff, Matthew A. "Pannellum: a lightweight web-based panorama viewer." Journal of Open Source Software 4, no. 40 (2019): 1628. doi:10.21105/joss.01628
Top Related Projects
A 360° media viewer for the modern web.
Javascript panorama viewer based on Three.js
An open-source, web-based viewer for zoomable images, implemented in pure JavaScript.
:a: Web framework for building virtual reality experiences.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot