# 场景加载

在本教程中,你可以通过BIMFACE提供的球体GIS场景模块加载场景,并为后续的场景应用做好准备。

提示:本教程需要先创建球体场景并完成发布,场景的搭建方法可参考场景搭建 (opens new window)

# 教程

球体场景加载方式与加载显示模型 (opens new window)加载显示图纸 (opens new window)的模式基本保持一致。

区分于平面GIS场景的加载,球体GIS的接口命名空间统一为Glodon.Bimface.Earth.xxx。

引用BIMFACE的JavaScript显示组件库 在使用BIMFACE JSSDK之前,你需要新建一个HTML文件,并在浏览器中打开。

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <title>My first scene in BIMFACE</title>
</head>

<body>
  <script src="https://static.bimface.com/api/BimfaceSDKLoader/BimfaceSDKLoader@latest-release.js" charset="utf-8"></script>
  <script>
    // 在这里输入BIMFACE JavaScript SDK提供的方法
  </script>
</body>

</html>
# 新建DOM元素

BIMFACE使用了HTML5的div元素作为容器,你可以方便的在Web上进行模型、图纸或场景的二次开发。这里,我们在HTML中新建一个div元素,将其ID设定为“domId”,并设置其宽度和高度。

这里,你可以将div元素的ID修改为其他值,但需要注意在之后根据ID获取div元素的时候也相应的做出修改。

<div id="domId" style="width:800px; height:600px"></div>
# 声明viewer及app变量

你需要声明viewer和app这两个变量,其中viewer将会用于对球体场景进行操作,app则可以获取到默认UI组件。

// 声明viewer及app变量
let viewer, app;
# 构造Loader并指定待加载的场景

BimfaceSDKLoader是BIMFACE提供的SDK加载器(loader)对象,loader会根据所需加载的资源来加载对应的js组件。你需要调用loader的加载方法,并利用View Token为其指定所要加载的资源。

为了在网页中显示指定的场景,需要其View Token作为标识。需要注意的是,View Token只是一个临时的访问凭证,有效期为12小时。当超过12小时后,你需要重新进行获取View Token (opens new window)的操作。

调用加载方法前,你需要先构造BimfaceSDKLoaderConfig作为loader的配置项,并设置相关的参数。这里我们先只指定View Token,你也可以在配置项中设置SDK版本号,具体内容相见接口文档 (opens new window)

// 声明viewToken变量,填入想要显示的GIS场景token
let viewToken = '<yourViewToken>';

// 构造BimfaceSDKLoaderConfig对象
let loaderConfig = new BimfaceSDKLoaderConfig();
// 设置BimfaceSDKLoaderConfig的viewToken
loaderConfig.viewToken = viewToken;

// 调用BimfaceSDKLoader的load方法加载模型
BimfaceSDKLoader.load(loaderConfig, successCallback, failureCallback);
# 设置加载资源后的回调函数

相信你已经注意到,我们在调用BimfaceSDKLoader.load方法时,分别传入了successCallback、failureCallback两个未定义的参数,它们分别是SDKLoader加载指定资源成功及失败的回调函数。这里,我们开始对其进行定义,当完成定义后,你就能看到场景在页面中加载出来了。

我们先定义加载成功的回调函数。对于加载包含默认UI的场景,可以分为以下几个步骤

  • 获取html中添加的div元素
  • 构造WebApplicationGIS对象,并与指定的div元素关联
  • 在WebApplicationGIS中加载场景
  • 获取到viewer对象,进行后续的二次开发
// 加载成功回调函数
function successCallback(viewMetaData) {

  // 获取DOM元素
  let domShow = document.getElementById('domId');

  // 创建WebApplicationGISConfig
  let webAppConfig = new Glodon.Bimface.Earth.Application.WebApplicationGISConfig();
  
  // 设置创建WebApplicationGIS的dom对象
  webAppConfig.domElement = domShow;
  // 创建WebApplicationGIS
  app = new Glodon.Bimface.Earth.Application.WebApplicationGIS(webAppConfig);

  // 加载待显示的场景
  app.addScene(viewToken);

  // 获取ViewerGIS对象
  viewer = app.getViewer();

};

注意到,我们对之前声明的viewer及app变量进行了赋值,这里的viewer即整个场景对象,之后几节教程中对于图层、构件等操作都会从viewer作为起点进行。

最后,我们定义加载失败的回调函数。

// 加载失败回调函数
function failureCallback(error) {

  console.log(error);

};
# 运行结果

输入以上代码,浏览器就可以加载我们的场景了。

# 完整代码

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <title>My first scene in BIMFACE</title>
</head>

<body>
  <div id="domId" style="width:800px; height:600px"></div>
  <script src="https://static.bimface.com/api/BimfaceSDKLoader/BimfaceSDKLoader@latest-release.js" charset="utf-8"></script>
  <script>
    // 声明viewer及app变量
    let viewer, app;
    // 声明viewToken变量,填入想要显示的模型/图纸/场景token
    let viewToken = '<yourViewToken>';
      
    // 构造BimfaceSDKLoaderConfig对象
    let loaderConfig = new BimfaceSDKLoaderConfig();
    // 设置BimfaceSDKLoaderConfig的viewToken
    loaderConfig.viewToken = viewToken;

    // 调用BimfaceSDKLoader的load方法加载模型
    BimfaceSDKLoader.load(loaderConfig, successCallback, failureCallback);

    // 加载成功回调函数
    function successCallback(viewMetaData) {

      // 获取DOM元素
      let domShow = document.getElementById('domId');
      // 创建WebApplicationGISConfig
      let webAppConfig = new Glodon.Bimface.Earth.Application.WebApplicationGISConfig();
      // 设置创建WebApplicationGIS的dom对象
      webAppConfig.domElement = domShow;
      // 创建WebApplicationGIS
      app = new Glodon.Bimface.Earth.Application.WebApplicationGIS(webAppConfig);

      // 加载待显示的场景
      app.addScene(viewToken);

      // 获取ViewerGIS对象
      viewer = app.getViewer();

    };

    // 加载失败回调函数
    function failureCallback(error) {

      console.log(error);

    };
  </script>
</body>

</html>

你已经成功加载了球体场景,接下来你将学习到图层管理 (opens new window)相关的知识。