Installation
Before installing, you will need to create an SDK key.
To manage keys, log in to your account, navigate to Account Settings -> Developer Tools, and scroll down to “SDK Key Management”. Click “Add an SDK Key” and add any desired local domains to the allow list (for example, localhost
and localhost:8080
).
To learn more about our developer tools, please visit the Matterport Developer Tools and Pricing
Once you have an SDK key, there are two methods for adding the Embed SDK to your site:
- Script tag (standard method)
- NPM package (beta)
Updates
Latest Embed SDK update: Jan 14, 2025
See the change log
<script>
support
<script>
tag. There is also an NPM package available.Include the Library and Add a Matterport Space
First, download the SDK bootstrap and add it to the project.
Optionally, set up an importmap. This line goes in the <head>
tag with your other includes.
<script type="importmap">
{
"imports": {
"MP_SDK": "./[path]/[to]/sdk.es6.js?applicationKey=[YOUR_SDK_KEY_HERE]"
}
}
</script>
Be sure to include the applicationKey when importing the library.
Next, embed a Matterport Space on your web page with an <iframe>
tag. Learn more about embedding.
Add the applicationKey=[YOUR SDK_KEY] URL parameter to provide your sdk key as part of the url.
Give the <iframe>
an ID you will use later.
<iframe
width="853"
height="480"
src="https://my.matterport.com/show?m=SxQL3iGyoDo&play=1&applicationKey=[YOUR_SDK_KEY_HERE]"
frameborder="0"
allow="fullscreen; vr"
id="showcase-iframe">
</iframe>
Connect to the Matterport Space
Now in the Javascript code for your web application, connect to the Matterport Space.
You’ll want to wait until the <iframe>
containing the Matterport Space loads. Connecting happens after you’ve included the SDK library.
Replace the [YOUR_SDK_KEY_HERE] string with your sdk key.
// if using the importmap
import { connect } from 'MP_SDK';
// if importing directly
import { connect } from './[path]/[to]/sdk.es6.js'
const iframe = document.getElementById('showcase-iframe');
// connect the sdk; log an error and stop if there were any connection issues
try {
const mpSdk = await connect(iframe);
onShowcaseConnect(mpSdk);
} catch (e) {
console.error(e);
}
function onShowcaseConnect(mpSdk) {
// start making calls on mpSdk as described in the reference docs
}
Parameter | Description |
---|---|
showcase-iframe |
The value you put for the the id parameter in the <iframe> tag earlier. |
applicationKey |
Your SDK key is unique to your website domain. Go to Matterport Account Settings -> Developer Tools to create an SDK key for your application. |
Legacy window.MP_SDK Support
Previous versions of the SDK set up a window.MP_SDK
object with a connect
function. To continue using this same connect method, use the non-ES6 version.
<script src="https://static.matterport.com/showcase-sdk/bootstrap/3.0.0-0-g0517b8d76c/sdk.js&applicationKey=[YOUR_SDK_KEY]"></script>
<script>
window.MP_SDK.connect(iframe, 'applicationkey')
</script>
However, connecting to a space with OAuth through the SDK is not supported by this version of the bootstrap. If support for OAuth is necessary, you will need to use the aforementioned sdk.es6.js
instead.
Control 3D Showcase with Actions
Now you’ll want to make an action for 3D Showcase to execute. In the code for your web application, add this to a Javascript function where desired. Refer to the reference docs for a list of all the actions you can do.
mpSdk.<action>(<arguments>).then(successCallback)
.catch(errorCallback);
// ...
// What to do if action was successful
function successCallback(message) { console.log(message); }
// What to do if the action failed
function errorCallback(err) { console.error(err); }
Parameter | Description |
---|---|
<action> |
The action you want 3D Showcase to do. |
<arguments> |
The arguments for that action. |
Listen to Events from 3D Showcase
Listening for events from 3D Showcase is done in a similar way.
mpSdk.on(<event_name>, function (<state_arguments>) {
// what to do when this event happens
});
Parameter | Description |
---|---|
<event_name> |
Event you’re listening for |
<state_arguments> |
Return values related to this event. These tell you about the new state of 3D Showcase after this event has happened. |
Use the Metadata
Finally, you can grab metadata about the entire Matterport Space by calling getData()
and getDetails()
in your web app. For example:
mpSdk.Model.getData()
.then(function(model) {
// Model data successfully retrieved
console.log('Model sid:' + model.sid);
})
.catch(function(error) {
// Problem retrieving model data
});
Metadata is only available after you have successfully connected to the Matterport Space.
NPM SDK Embed Package
<script>
tag. The NPM package is in beta - feedback to developer@matterport.com is welcome.The NPM SDK Embed package allows you to use the Embed SDK directly from your NPM or Yarn projects. See the docs on NPM for the latest instructions.
See here for a tutorial on getting started with the package.