Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

track.html 2.2KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8" />
  5. <meta name="viewport" content="width=device-width,initial-scale=1.0" />
  6. <title>dc-example</title>
  7. <script src="/libs/dc-sdk/dc.min.js"></script>
  8. <link href="/libs/dc-sdk/dc.min.css" type="text/css" rel="stylesheet" />
  9. <link href="../index.css" type="text/css" rel="stylesheet" />
  10. </head>
  11. <body>
  12. <div id="viewer-container" class="viewer-container"></div>
  13. <div class="btn-box">
  14. <ul>
  15. <li><button onclick="play()">播放</button></li>
  16. <li><button onclick="pause()">暂停</button></li>
  17. <li><button onclick="restore()">恢复</button></li>
  18. <li><button onclick="view('1',-20,100)">第一视角</button></li>
  19. <li><button onclick="view('2')">上帝视角</button></li>
  20. <li><button onclick="view('tracked')">跟随视角</button></li>
  21. <li><button onclick="view('free')">自由视角</button></li>
  22. </ul>
  23. </div>
  24. <script>
  25. DC.config.baseUrl = '../libs/dc-sdk/resources/'
  26. let viewer = new DC.Viewer('viewer-container')
  27. let baseLayer = DC.ImageryLayerFactory.createImageryLayer(
  28. DC.ImageryType.AMAP,
  29. {
  30. crs: 'WGS84',
  31. }
  32. )
  33. viewer.addBaseLayer(baseLayer)
  34. let positions =
  35. '120.71450195156326,31.34008410150321;120.71575718410492, 31.32906254460538;120.71755047923497, 31.319390534202;120.71992195728619, 31.31036033288049;120.72027974558881, 31.3011861708824;120.72044382952038,31.288363396025954;120.72063046005844, 31.281477152748355;120.72044354666637,31.27731493354631'
  36. let tc = new DC.TrackController(viewer)
  37. let track = new DC.Track(positions, 20)
  38. track.setModel('../assets/data/qiche.gltf', {
  39. scale: 1,
  40. })
  41. tc.addTrack(track)
  42. viewer.flyToPosition(
  43. '120.71650745697383,31.325149960836068,2817.8608257878627,0,-70'
  44. )
  45. function play() {
  46. tc.play()
  47. }
  48. function pause() {
  49. tc.pause()
  50. }
  51. function restore() {
  52. tc.restore()
  53. }
  54. function view(mode, pitch, range) {
  55. tc.viewTrack(track, {
  56. mode: mode,
  57. pitch: pitch,
  58. range: range,
  59. })
  60. }
  61. </script>
  62. </body>
  63. </html>