当前位置:网站首页>photo-sphere-viewer Chinese documentation

photo-sphere-viewer Chinese documentation

2022-08-02 12:33:00 m0_67400972

photo-sphere-viewer中文文档

勤学如春起之苗,不见其增,日有所长;
辍学如磨刀之石,不见其损,日有所亏.

On one side of the business want to achieve the effect of the links on the rightAli cloud paid panorama,类似VR看房,支持360° x 360°任意旋转,支持Custom add mark,支持切换场景等功能,效果如下

在这里插入图片描述

We have to pay for ali cloud panorama,而且Individual function is not meet our business needs,There can't adjust,So by our internal implementation behind

The front leader here provides aphoto-sphere-viewerRelated articles for reference

内部基于 photo-sphere-viewer Plug-in implementation effect is as follows
在这里插入图片描述

Panorama implementations use photo-sphere-viewer 插件,它基于three.js和uEvent 2实现

This implementation mainly use photo-sphere-viewer和他的标记Markers插件

安装插件

使用 npm 或 yarn 下载安装

npm install photo-sphere-viewer --save

yarn add photo-sphere-viewer 

文章使用的版本"photo-sphere-viewer": "^4.3.0"

使用如下

import MarkersPlugin from 'photo-sphere-viewer/dist/plugins/markers'
import 'photo-sphere-viewer/dist/plugins/markers.css';

import { MarkersPlugin } from 'photo-sphere-viewer/dist/plugins/markers'
import 'photo-sphere-viewer/dist/plugins/markers.css'

this.viewer = new Viewer({
    container:document.querySelector('#viewer'),
    panorama:'https://aupup-mall-pub.oss-cn-shenzhen.aliyuncs.com/public/aa28925e-8ef9-4a2d-9217-e82a86b6ee15.jpg',
    size:{
        width: '100%',
        height: '100%',
    },
    plugins: [
        [MarkersPlugin, {
            markers: [
                {
                    id:'circle',
                    tooltip:'A circle of radius 30',
                    circle:30,
                    svgStyle : {
                        fill:'rgba(255,255,0,0.3)',
                        stroke:'yellow',
                        strokeWidth:'2px',
                    },
                    longitude: -1.5,
                    latitude: -0.28,
                    anchor: 'center right',
                }
            ],
        }],
    ],
});

Configuration 配置项

在这里插入图片描述

A strange object,打断点后,去控制台查看,Method can easily see the object's properties such as information

Standard options 常规配置

container (required)

  • type: HTMLElement | string

Panorama of the container,可以是DOM元素或者DOM的ID

container: document.querySelector('.viewer')

container: 'viewer' // will target [id="viewer"]

adapter 适配器

  • default: equirectangular

Used for loading the panorama of the adapter

panorama (required)

  • type: *

全景图地址,If you use the default adapter,Only supports the leaflet

plugins 插件

  • type: array

Introduction to plugins
Here only to tagging plugin,后面单独介绍

caption 标题

  • type: string

导航栏中显示的文本.如果导航栏被禁用,Anyway it shows,但没有按钮.允许使用 HTML

size Panorama width height

  • type: { width: integer, height: integer }

A panoramic view of the final size of the container.By default, use the container size,And adjust the window size during the following

markers 标注

Annotation configuration

navbar 导航栏

导航栏的配置

minFov

  • type: integer
  • default: 30

Minimum vision(Corresponding to the maximum zoom),介于 1 和 179 之间.

maxFov

  • type: integer
  • default: 90

最大视野(Corresponding to the minimum zoom),介于 1 和 179 之间

defaultZoomLvl

  • type: integer
  • default: 50

初始缩放级别,介于 0(对于 maxFov)和 100(对于 minfov)之间.

fisheye

  • type: boolean | double
  • default: false

使用 true Enable the fisheye effects or specified effect intensity (true = 1.0).

PS: This pattern may produce side effects to tag render

defaultLong

  • type: double | string
  • default: 0
    The initial longitude,介于 0 和 2π 之间

defaultLat

  • type: double | string
  • default: 0
    The initial latitude,介于 -π/2 和 π/2 之间.

longitudeRange

插件VisibleRangePlugin

latitudeRange

插件VisibleRangePlugin

autorotateDelay

  • type: integer
  • default: null

Automatic rotation delay after the beginning of the,以毫秒为单位

autorotateSpeed

  • type: string
  • default: 2rpm

Automatic rotation speed

autorotateLat

  • type: double | string
  • default: defaultLat

Perform automatic rotating latitude

lang

  • type: object
    -default:

    lang: {
    autorotate: ‘Automatic rotation’,
    zoom : ‘Zoom’,
    zoomOut : ‘Zoom out’,
    zoomIn : ‘Zoom in’,
    move : ‘Move’,
    download : ‘Download’,
    fullscreen: ‘Fullscreen’,
    menu : ‘Menu’,
    twoFingers: ‘Use two fingers to navigate’,
    ctrlZoom : ‘Use ctrl + scroll to zoom the image’,
    loadError : ‘The panorama can’t be loaded’,
    }

Viewer is used in a variety of text

loadingImg

  • type: string

To show the path of the image in the center of the loading circle,也就是loading图

loadingTxt

  • type: string
  • default: ‘Loading…’

Loading circle center displays the text,In not only provideloadingImg时使用

mousewheel

  • type: boolean
  • default: true

Use the mouse wheel to enable the zoom,Scaling process would hide markstooltip内容

mousemove

  • type: boolean
  • default: true

Use the mouse cursor or fingers slide on the touch screen to enable panoramic rotation

mousewheelCtrlKey

  • type: boolean
  • default: false

需要使用 ctrl Key to zoom panorama.Allowed in the case of does not interfere with the viewer scroll.如果启用,When there is no press ctrl 键时,Displays require the user to use ctrl + Scrolling overlays

captureCursor

  • type: boolean
  • default: false

Just move the cursor to the top view rather than click+Move to rotate panorama

touchmoveTwoFingers

  • type: boolean
  • default: false

Need two fingers to rotate the view.This allows the in page contains the viewer standard touch scroll navigation.如果启用,When detected only once touch,Displays require the user to use two fingers overlays

Advanced options 高级选项

The business development process,还没用到

sphereCorrection Spherical correction

  • type: { pan: double, tilt: double, roll: double }
  • default: { pan:0, tilt:0, roll: 0 }

Sphere rotation Angle,以弧度为单位.

PS: 如果 XMP 数据和/或 panoData Contains the course/俯仰/滚动数据,它们将在 sphereCorrection 之前应用

moveSpeed

  • type: double
  • default 1

Panoramic mobile speed multiplier.To click the mobile、Touch mobile and navigation button.

zoomSpeed

  • type: double
  • default 1

Used for panoramic zoom speed multiplier.Used in the mouse wheel、Touch the kneading and navigation button.

useXmpData

  • type: boolean
  • default true

从 XMP Data reads the real image size,If the panoramic camera after cutting,You must keep it real

panoData 全景数据

  • type: object | function<Image, object>

Covering the panorama, found in the file XMP 数据(或者在 useXmpData=false Simply define it).所有参数都是可选的.

panoData: {
  fullWidth: 6000,
  fullHeight: 3000,
  croppedWidth: 4000,
  croppedHeight: 2000,
  croppedX: 1000,
  croppedY: 500,
  poseHeading: 270, // 0 to 360
  posePitch: 0, // -90 to 90
  poseRoll: 0, // -180 to 180
}

It also can be calculated according to image dynamic load cutting configuration function.

panoData: (image) => ({
  fullWidth    : image.width,
  fullHeight   : image.width / 2,
  croppedWidth : image.width,
  croppedHeight: image.height,
  croppedX     : 0,
  croppedY     : image.width / 2 - image.height,
})

PS: 如果 XMP 数据和/或 panoData Contains the course/俯仰/滚动数据,它们将在 sphereCorrection 之前应用

requestHeaders

  • type: object | function<string, object>

When loading the image file Settings HTTP 请求头.

requestHeaders: {
  header: value,
}

It can also be dynamically setting before each call to request header function.这在向 Authorization The header to add temporary effective Bearer 时很有用.

requestHeaders: (url) => ({
   header: value,
})

canvasBackground

  • type: string
  • default: #000

The background of the canvas,When using cutting panorama visible

moveInertia

  • type: boolean
  • default: true

After manual mobile enable smooth animation

clickEventOnMarker

插件MarkersPlugin,后面会介绍

withCredentials

  • type: boolean
  • default: false

对 HTTP Request using credentials.

keyboard 键盘

  • type: boolean | object

  • default:

    keyboard: {
    ‘ArrowUp’: ‘rotateLatitudeUp’,
    ‘ArrowDown’: ‘rotateLatitudeDown’,
    ‘ArrowRight’: ‘rotateLongitudeRight’,
    ‘ArrowLeft’: ‘rotateLongitudeLeft’,
    ‘PageUp’: ‘zoomIn’,
    ‘PageDown’: ‘zoomOut’,
    ‘+’: ‘zoomIn’,
    ‘-’: ‘zoomOut’,
    ’ ': ‘toggleAutorotate’
    }

Enabled and configured full-screen keyboard navigation.It is a defined key code->动作的映射.设置为 false 以禁用. (The above lists all available operating)

Viewer Methods方法

Many methods can be used to from your application controlViewer. API 文档Provides a complete list of methods in

Before call any way waiting forViewerReady event is a good idea.

viewer.once('ready', () => {
  viewer.rotate({
    x: 1500,
    y: 1000
  });
});

常用方法

Here just list the commonly used method,A complete list of the methods we can see API 文档.

Initialize the panorama

import { Viewer } from 'photo-sphere-viewer'
import 'photo-sphere-viewer/dist/photo-sphere-viewer.css'

// Initialize the panorama
this.viewer = new Viewer({
  container: document.querySelector('#viewer'),
  panorama: 'https://aupup-mall-pub.oss-cn-shenzhen.aliyuncs.com/public/aa28925e-8ef9-4a2d-9217-e82a86b6ee15.jpg', // 全景图地址 
  size: {
    width: '100%',
    height: '100%'
  }
})

animate(options): Animation

Use smooth animation rotate and zoom the view.可以更改位置(经度、Latitude or x、y)和缩放级别(缩放).

Speed option is based on the duration of milliseconds or included in RPM (2rpm) Or a second degree (10dps) Units of the speed of the string.

它返回一个 PSV.Animation,It is a method with additional cancelled standard Promise.

viewer.animate({
  longitude: Math.PI / 2,
  latitude: '20deg',
  zoom: 50,
  speed: '-2rpm',
})
  .then(() => /* animation complete */);

destroy()

从页面中删除Viewer并释放three.js 使用的内存.

Vue项目中,Panorama switch,Need to uninstall first panoramic view of the current

// Switching scenarios Destruction of the original scene first
// 有时候this.viewer.destroy()执行会报错 如果报错 这里手动removeOff the corresponding elements
  if (this.viewer) try {
    this.viewer.destroy()
  } catch (e) {
    console.log(e)
    const viewer = document.querySelector('#viewer')
    viewer.removeChild(viewer.childNodes[0])
  }

getPosition(): Position

Returns the view current location

getZoomLevel(): number

返回 0 到 100 Between the current zoom level

rotate(position)

Rotating immediately without animation view.

// you can also use longitude and latitude
viewer.rotate({
  x: 1500,
  y: 600,
});

setOption(option, value)

Update the viewer options.Some options cannot be changed:全景、全景数据、容器、The adapter and plug-ins

viewer.setOption('fisheye', true);

setOptions(options)

An update multiple options.

viewer.setOptions({
  fisheye: true,
  autorotateSpeed: '-1rpm',
});
setPanorama(panorama, options): Promise

Using an optional transition animations(默认启用)Change the panoramic image.如果需要,You can also set the new sphereCorrection 和 panoData

viewer.setPanorama('image.jpg')
  .then(() => /* update complete */);

zoom(level) | zoomIn() | zoomOut()

In the absence of animation change the zoom level.

Events 事件

Photo Sphere Viewer使用uEvent API,API 文档Provides a complete list of events

Event listeners to a Event 对象作为第一个参数,This object is generally not used.After this event object can use other parameters.

常用事件

This section describes the commonly used events,请记得查看 API 文档以获取完整列表

Initialize the panorama

import { Viewer } from 'photo-sphere-viewer'
import 'photo-sphere-viewer/dist/photo-sphere-viewer.css'

// Initialize the panorama
this.viewer = new Viewer({
  container: document.querySelector('#viewer'),
  panorama, // 全景图地址 
  size: {
    width: '100%',
    height: '100%'
  }
})

Panorama click event click(data) | dblclick(data)

When the user clicks the viewer(Of all the places in addition to the navigation bar and side panels)时触发,It contains a lot of information about users to click on the location of the,如果启用了 clickEventOnMarker 选项,Includes a tag.

viewer.on('click', (e, data) => {
  console.log(`${data.rightclick?'right ':''}clicked at longitude: ${data.longitude} latitude: ${data.latitude}`);
});

Click event is always dblclick 之前触发

Vue项目中使用

this.viewer.on('click', (e, data) => {
    // Click on the panorama events
    console.log('e:', e)
    console.log('data:', data)
}

在这里插入图片描述

Panorama location change is triggered when the callback position-updated(position)

When the view and longitude/Or latitude change triggered when.

viewer.on('position-updated', (e, position) => {
  console.log(`new position is longitude: ${position.longitude} latitude: ${position.latitude}`);
});

VueThe project using the following

this.viewer.on('position-updated', (e, position) => {
        console.log({ e })
        console.log({ position })
        // Panorama location changes Display is rotating, they'll put marktooltip内容隐藏 Stop rotating here Let this part of the marktooltip重新展示
        // config.tooltip?.visibleIs manually add variables Used to judge marktooltip是否显示
        if (this.markersPlugin && this.markersPlugin.markers && this.currentMarkerId) setTimeout(() => {
          Object.keys(this.markersPlugin.markers).forEach((id) => {
            if (this.markersPlugin.markers[id].config.tooltip?.visible) this.markersPlugin.markers[id]['showTooltip']()
          })
        }, 300)
      })

在这里插入图片描述

在这里插入图片描述

Panorama the callback when loaded ready

When a panoramic image is loaded andViewerReady to perform the first rendering triggered when.

viewer.once('ready', () => {
  console.log(`viewer is ready`);
});

项目中在readyAfter will obtain annotation data,生成标注

  this.viewer.once('ready', () => {
    // Remove the first screenloading
    this.fullLoading = false
    // 初始化标注
    this.initMarkers()
    // Automatic horizontal rotation
    // this.viewer.startAutorotate()
  })

Panorama of scaling back zoom-updated(level)

viewer.on('zoom-updated', (e, level) => {
  console.log(`new zoom level is ${level}`);
});

MarkersPlugin Tagging plugin

Displayed on the viewer and the various tags/热点.API文档

The plug-in file is located in thephoto-sphere-viewer依赖包的dist/plugins/markers.jsdist/plugins/markers.css.

请添加图片描述

用法

The plug-in provides a powerful tag system,允许使用Optional tool tip描述Define panorama on points of interest.Tags can be动态添加/删除,You can click on to the customer/Click on the response.

There are four types of tag

  • 使用 html 属性定义的 HTML
  • 使用 image Attribute defines the image
  • 使用 rect、circle、ellipse 或 path 属性定义的 SVG

During initialization panorama using the tag options or after loading using various methods to add tags.

import { Viewer } from 'photo-sphere-viewer'
import 'photo-sphere-viewer/dist/photo-sphere-viewer.css'

import { MarkersPlugin } from 'photo-sphere-viewer/dist/plugins/markers'
import 'photo-sphere-viewer/dist/plugins/markers.css'

this.viewer = new Viewer({
  container: document.querySelector('#viewer'),
  panorama: 'https://aupup-mall-pub.oss-cn-shenzhen.aliyuncs.com/public/aa28925e-8ef9-4a2d-9217-e82a86b6ee15.jpg', // 全景图片
  mousewheel: false,
  fisheye: 1,
  size: {
    width: '100%',
    height: '100%'
  },
  plugins: [
    [
      MarkersPlugin,
      {
        markers: []
      }
    ]
  ],
  navbar: []
})

this.markersPlugin = this.viewer.getPlugin(MarkersPlugin)

const markerConfig = {
    "id":161,
    "status":1,
    "anchor":"center center",
    "html":"<div class="marker-content-container published"></div><div class="init-title">图片test</div>",
    "imageId":21,
    "latitude":"-0.2424036312917366",
    "longitude":"5.328437925876281",
    "tooltip":{
        "content":"
              <div class="marker-tooltip-container">
                  <div class="marker-img-continaer">
                  
          <div class="scroll-container marker-img-scroll-container "><img src=https://aupup-mall-pub.oss-cn-shenzhen.aliyuncs.com/public/a5bd77be-f63d-4e8e-99f0-03b6fca26d03.png /><img src=https://aupup-mall-pub.oss-cn-shenzhen.aliyuncs.com/public/a00b18c3-6e0a-4166-b6fe-582490c83222.jpg /><img src=https://aupup-mall-pub.oss-cn-shenzhen.aliyuncs.com/public/0e39486e-9bea-4581-96c3-3f1a2f8ab4c3.png /></div>
          <img class="btn toLeft imgToLeft" src=>
              <img class="btn toRight imgToRight" src=>
                </div>
                <p class="marker-title">
                  图片test
                </p>
                <p class="marker-description" style=display:none;>
                  
                </p>
              </div>
            ",
        "position":"center top"
    },
    "type":"marker",
    "title":"图片test",
    "description":null,
    "attachment":{
        "type":"img",
        "imgArr":[
            "https://aupup-mall-pub.oss-cn-shenzhen.aliyuncs.com/public/a5bd77be-f63d-4e8e-99f0-03b6fca26d03.png",
            "https://aupup-mall-pub.oss-cn-shenzhen.aliyuncs.com/public/a00b18c3-6e0a-4166-b6fe-582490c83222.jpg",
            "https://aupup-mall-pub.oss-cn-shenzhen.aliyuncs.com/public/0e39486e-9bea-4581-96c3-3f1a2f8ab4c3.png"
        ],
        "videoArr":[

        ],
        "linkText":"",
        "link":""
    },
    "angle":null,
    "targetSceneId":-1,
    "isFirstInitMarker":true
}

this.markersPlugin.addMarker(markerConfig)

打印this.markersPlugin

请添加图片描述

markersObject of every attribute is a label,keyValue is the mark ofid

With the configuration of the focus onhtmltooltip属性,这里都用了html字符串,It's easy custom,样式和交互,
请添加图片描述

In addition to the following form the properties of the,The other is the custom,Used to save edit data,然后生成html和tooltip字段的内容

Annotations define

A label must have at least one configuration below

Name

Type

Description

image

string

The path of the said mark image.You need to define the width and height.

html

string

标记的 HTML 内容.Suggested that define the width and height.

square

integer

The size of the square

rect

integer[2] |
{width:int,height:int}

The size of the rectangle

circle

integer

圆的半径

ellipse

integer[2] |
{cx:int,cy:int}

椭圆的半径.

path

string

路径的定义(0,0 Will be placed in the definition of x/y Or longitude/纬度处).

polygonPx

integer[2][]

On the panoramic image pixel coordinates are defined in the polygon points set.

polygonRad

double[2][]

同上,But the coordinate is the longitude and latitude.

polylinePx

integer[2][]

与polygonPx 相同,But generate more section of the line.

polylineRad

double[2][]

与polygonRad 相同,But generate more section of the line.

Examples :

{
  image: 'pin-red.png',
  html: 'Click here',
  square: 10,
  rect: [10, 5],
  rect: {width: 10, height: 5},
  circle: 10,
  ellipse: [10, 5],
  ellipse: {cx: 10, cy: 5},
  path: 'M 0 0 L 60 60 L 60 0 L 0 60 L 0 0',
  polygonPx: [[100, 200], [150, 300], [300, 200]],
  polygonRad: [[0.2, 0.4], [0.9, 1.1], [1.5, 0.7]],
  polylinePx: [[100, 200], [150, 300]],
  polylineRad: [[0.2, 0.4], [0.9, 1.1]],
}

PS:Texture coordinates does not apply to the cube map.

Annotation configuration items

id (required)

  • type: string

标记的唯一标识符.

x & y or latitude & longitude (required)

  • type: integer or double

Tag in the texture coordinates(像素)Or spherical coordinates(弧度)中的位置. (Polygon and polyline ignore this option)

width & height (required for images, recommended for html)

  • type: integer

标记的大小. (Polygon and polyline ignore this option)

scale

  • type: double[] | { zoom: double[], longitude: [] }
  • default: no scalling

According to the zoom level and/Or the proportion of longitude migration configuration tag.This is aimed at the user scale and the size of the moves to provide natural feeling. (Polygon and polyline ignore this option)

According to the zoom zoom,数组包含[With the minimum scaling zoom,With the largest scale zoom]

scale: {
  // Mark on the minimum zoom level two times
  zoom: [0.5, 1]
}

// same thing
scale: [0.5, 1]

According to its location zoom,数组包含 [中心缩放,The side zoom]

scale: {
  // Tag at the side of the screen when two times
  longitude: [1, 2]
}

Two kinds of configuration can be combined using

scale: {
  zoom: [0.5, 1],
  longitude: [1, 1.5]
}

className

  • type: string

Added to the class name of the tag element.

style

  • type: object

On the tag set of CSS 属性(背景、边框等).

style: {
  backgroundColor: 'rgba(0, 0, 0, 0.5)',
  cursor         : 'help'
}

svgStyle

  • type: object

On the tag set of SVG 属性(填充、描边等).仅适用于 SVG 和多边形/折线标记.

svgStyle: {
  fill       : 'rgba(0, 0, 0, 0.5)',
  stroke     : '#ff0000',
  strokeWidth: '2px'
}

Image and design background

Can use the schema definition to define complex SVG 背景,例如图像.

Somewhere in the page statement first model:

<svg id="patterns">
  <defs>
    <!-- define pattern origin on its center -->
    <pattern id="image" x="256" y="256" width="512" height="512" patternUnits="userSpaceOnUse">
      <image href="my-image.jpg" x="0" y="0" width="512" height="512"/>
    </pattern>
  </defs>
</svg>

And in the tag to use it:fill: 'url(#image)'.

anchor

  • type: string
  • default: ‘center center’

The placement of custom tag towards its defined position location.任何 CSS Location is valid,例如bottom center20% 80%. (Polygon and polyline ignore this option)

visible
  • type: boolean
  • default: true

标记的初始可见性.

tooltip

  • type: string | {content: string, position: string}
  • default: {content: null, position: ‘top center’}

tooltip内容和位置.To accept the position is at the top of the(top)、中间(center)、底部(bottom)和左侧(left)、中间(center)、右侧(right)的组合,中间居中(center center)除外.

tooltip: 'This is a marker' // tooltip with default position

tooltip: { // tooltip with custom position
  content : 'This is marker',
  position: 'bottom left'
}

content

  • type: string

Click the mark will show on the side panels of the HTML 内容

hideList

  • type: boolean
  • default: false

Hidden in the tag list tags.

data

  • type: any

To be attached to the mark of any custom data.

Configuration

lang

  • type: object

  • default:

    lang: {
    markers : ‘Markers’,
    markersList: ‘Markers list’,
    }

PS: This option is not a part of the plugin,But with the Lord lang 对象合并.

hideButton

  • type: boolean
  • default: true

Add navigation buttons to hide/显示标记.

listButton

  • type: boolean
  • default: true

Add navigation buttons to display a list of tags.

clickEventOnMarker

  • type: boolean
  • default: false

Click on the mark,除了触发select-marker 事件之外,Whether to triggerclick事件

Tagging methods

添加标注 addMarker(properties)

Add new tags to the panorama.

markersPlugin.addMarker({
  id: 'new-marker',
  longitude: '45deg',
  latitude: '0deg',
  image: 'assets/pin-red.png',
});

编辑状态下,Click on the panorama will first add a default label,然后编辑完成后,To update the label

请添加图片描述
在这里插入图片描述

Add initialization mark code refer to the following

    addMarker(e, data) {
      // Add initial mark After detailed annotation editor will update
      // currentTabIndex 1: 添加标注 2:添加跳转
      if (this.currentTabIndex === 1) {
        // console.log('添加标注')
        const id = `marker${+new Date()}`
        const config = {
          id,
          html: `
            <div class="marker-content-container">
            </div>
          `,
          longitude: data.longitude,
          latitude: data.latitude,
          anchor: 'center center',
          tooltip: {
            // tooltip with custom position
            content: `
              <div class="marker-tooltip-container">
                <p class="marker-title">
                  No input title
                </p>
                <p class="marker-description">
                  No input description
                </p>
              </div>
            `,
            position: 'center top'
          },
          visible: true, // With the initial display or not
          type: 'marker',
          status: 1,
          isInitialize: true,
          attachment: {
            type: 'img',
            imgArr: [],
            videoArr: []
          }
          // note: {
          //   type: 'marker', // 添加标注 or 添加跳转
          //   status: 1, // 0 未发布 1发布
          //   // target: '', // Want to jump the panorama of
          //   // angle: '', // 角度
          //   // sceneName: '', // Want to jump the scene name
          //   isInitialize: false // Whether the initialization values trueSaid is initializing Outstanding editor mark If ordered to cancel 需要删除  If the editing point save 值变为false
          // }
        }
        this.markersPlugin.addMarker(config)
        // 显示 tooltip
        this.markersPlugin.markers[id].showTooltip()

        // 隐藏 tooltip
        //   this.markersPlugin.markers[id].hideTooltip()
        this.currentMarkerId = id
      } else if (this.currentTabIndex === 2) {
        console.log('添加跳转')
        // console.log('添加跳转')
        const id = `jump${+new Date()}`
        const config = {
          id,
          html: `
          <div class="jump-container">
            <p class="jump-text">
              Temporarily not select the target scene
            </p>
            <img class="jump-arrow" src="https://aupup-mall-pub.oss-cn-shenzhen.aliyuncs.com/public/b254e741-96d5-40d9-aabd-853c5a2e332f.png"></img>
          </div>
          `,
          longitude: data.longitude,
          latitude: data.latitude,
          anchor: 'center center',
          type: 'jump',
          target: '',
          angle: '',
          sceneName: '',
          isInitialize: true,
          attachment: {
            type: 'img',
            imgArr: [],
            videoArr: []
          }
          // note: {
          //   type: 'jump', // 添加标注 or 添加跳转
          //   target: '', // Want to jump the panorama of
          //   angle: '', // 角度
          //   sceneName: '', // Want to jump the scene name
          //   isInitialize: false // Whether the initialization values trueSaid is initializing Outstanding editor mark If ordered to cancel 需要删除  If the editing point save 值变为false
          // }
        }
        this.markersPlugin.addMarker(config)
        this.currentMarkerId = id
      }
    },

Editor after the completion of the update label when saving code refer to the following

    async updateMarker() {
      // The custom edit content Update to the corresponding marked
      // currentTabIndex 1: 添加标注 2:添加跳转
      let config = {}
      const markerData = this.markersEditConfig.marker

      if (this.currentTabIndex === 1) {
        console.log('添加标注')
        if (!markerData.title) {
          this.$message.error('请填写标题')
          return false
        }

        const { title, description } = markerData
        let descriptionStyle = ''
        if (!description) descriptionStyle = 'display:none;'

        let attachment = '',
          content = ''
        switch (markerData.attachment.type) {
        case 'img': {
          const { length } = markerData.attachment.imgArr
          if (length > 0) {
            markerData.attachment.imgArr.forEach((src) => {
              attachment += `<img src=${src} />`
            })
            attachment = `
          <div class="scroll-container marker-img-scroll-container ">${attachment}</div>
          `
            // 左右箭头
            if (length > 1) attachment += `<img class="btn toLeft imgToLeft" src=${toLeft}>
              <img class="btn toRight imgToRight" src=${toRight}>`
            attachment = `<div class="marker-img-continaer">
                  ${attachment}
                </div>`
          }

          content = `
              <div class="marker-tooltip-container">
                  ${attachment}
                <p class="marker-title">
                  ${title}
                </p>
                <p class="marker-description" style=${descriptionStyle}>
                  ${description}
                </p>
              </div>
            `

          break
        }
        case 'video': {
          const { length } = markerData.attachment.videoArr
          if (length > 0) {
            markerData.attachment.videoArr.forEach((src) => {
              attachment += `
              <div>
                <video src=${src}></video>
                <img class="play-btn" data-src="${src}" src="https://aupup-mall-pub.oss-cn-shenzhen.aliyuncs.com/public/f1a83148-a573-4e46-a1c0-4c6db6752d81.png" />
              </div>
            `
            })
            attachment = `
            <div class="scroll-container marker-video-scroll-container">
                    ${attachment}
            </div>`
            //  左右箭头
            if (length > 1) attachment += `<img class="btn toLeft videoToLeft" src=${toLeft}>
              <img class="btn toRight videoToRight" src=${toRight}>
            `
            attachment = `<div class="marker-video-continaer">
                ${attachment}
                </div>  `
          }

          content = `
              <div class="marker-tooltip-container">
                ${attachment}
                <p class="marker-title">
                  ${title}
                </p>
                <p class="marker-description" style=${descriptionStyle}>
                  ${description}
                </p>
              </div>
            `
          break
        }
        case 'link':
          // linkJump address if without agreement 需要补充上
          if (!markerData.attachment.link.includes('http')) markerData.attachment.link = `https://${markerData.attachment.link}`
          attachment = `<a href="${markerData.attachment.link}" target="_blank">${markerData.attachment.linkText} ><span class="arrow">></span></span></a>`
          content = `
              <div class="marker-tooltip-container">
                <p class="marker-title">
                  ${title}
                </p>
                <p class="marker-description" style=${descriptionStyle}>
                  ${description}
                </p>
                <div class="marker-link-container">
                  ${attachment}
                </div>
              </div>
            `
          break
        default:
          console.log('default')
        }
        // console.log('content:', content)
        config = {
          id: this.currentMarkerId,
          html: `
            <div class="marker-content-container ${
  markerData.status ? 'published' : ''
}">
            </div>
          `,
          // longitude: data.longitude,
          // latitude: data.latitude,
          anchor: 'center center',
          tooltip: {
            // tooltip with custom position
            content,
            position: 'center top'
          },
          visible: true, // With the initial display or not
          isInitialize: false
          // note: {
          //   type: 'marker', // 添加标注 or 添加跳转
          //   status: 0, // 0 未发布 1发布
          //   isInitialize: true // Whether the initialization values trueSaid is initializing Outstanding editor mark If ordered to cancel 需要删除  If the editing point save 值变为false
          // }
        }
        this.markersPlugin.updateMarker(config)
        // 显示tooltip
        this.markersPlugin.markers[this.currentMarkerId].showTooltip()
      } else if (this.currentTabIndex === 2) {
        console.log('添加跳转')
        const { targetSceneId, angle } = this.markersEditConfig.jump
        if (!targetSceneId) {
          this.$message.error('Please select a jump scene')
          return false
        }
        const jumpConfig = this.sceneArr.find(
          (item) => item.id === targetSceneId
        )
        console.log('jumpConfig:', jumpConfig)
        config = {
          id: this.currentMarkerId,
          html: `
          <div class="jump-container">
            <p class="jump-text">
              ${jumpConfig.sceneName}
            </p>
            <img class="jump-arrow" style="transform:rotate(${angle.replace(
    '°',
    ''
  )}deg);" src="https://aupup-mall-pub.oss-cn-shenzhen.aliyuncs.com/public/b254e741-96d5-40d9-aabd-853c5a2e332f.png"></img>
          </div>
          `,
          isInitialize: false
          // note: {
          //   type: 'jump', // 添加标注 or 添加跳转
          //   target: jumpConfig.img, // Want to jump the panorama of
          //   angle, // 角度
          //   sceneName: jumpConfig.sceneName, // Want to jump the scene name
          //   isInitialize: true, // Whether the initialization values trueSaid is initializing Outstanding editor mark If ordered to cancel 需要删除  If the editing point save 值变为false
          //   sceneId: targetSceneId // 跳转场景id
          // }
        }

        this.markersPlugin.updateMarker(config)
      }
      config = {
        ...this.markersPlugin.markers[this.currentMarkerId].config,
        ...config
      }
      config.imageId = this.sceneArr[this.currentSceneIndex].id
      // The new label
      // 调整参数
      config.type = this.currentTabIndex === 1 ? 'marker' : 'jump'
      if (config.type === 'marker') {
        config.title = markerData.title
        config.description = markerData.description
        config.attachment = markerData.attachment
      } else if (config.type === 'jump') {
        config.angle = this.markersEditConfig.jump.angle
        config.targetSceneId = this.markersEditConfig.jump.targetSceneId
      }
      console.log('调整后的config:', config)
      // id为number类型 更新 否则 新增
      let res
      if (typeof config.id === 'number') res = await this.$api.updateMarker(config)
      else res = await this.$api.addMarker(config)
      if (res.success) {
        // console.log('config.id:', config.id)
        this.markersPlugin.removeMarker(config.id)
        this.isEditMarker = false
        this.$nextTick(() => {
          this.initMarkers()
        })
      }
    },

Remove all annotations clearMarkers()

删除所有标记.

Gets the current label getCurrentMarker(): Marker

Returns the user clicks the last tag

To specify annotations gotoMarker(id, speed): Animation

使用Optional animationMove the view to the center of the particular tag.

markersPlugin.gotoMarker('marker-1', 1500)
  .then(() => /* animation complete */);

隐藏/显示 标注 hideMarker(id) | showMarker(id) | toggleMarker(id)

Change marks the visibility of the

removeMarker(id) | removeMarkers(ids)

删除标记

Replace marked setMarkers(properties[])

Replace with new tag all the tags

Update mark updateMarker(properties)

Using the new attribute update tag.Tag type cannot be changed

markersPlugin.updateMarker({
  id: 'existing-marker',
  image: 'assets/pin-blue.png'
});

标记事件

over-marker(marker) | leave-marker(marker)

When the user the cursor hover or away from mark triggered when.

markersPlugin.on('over-marker', (e, marker) => {
  console.log(`Cursor is over marker ${marker.id}`);
});

select-marker(marker, data)

When the user clicks on a tag to trigger.dataObject indicates whether by double-clicking right click to select tags.

在这里插入图片描述

Plug-in was controlled by the mouse to come outtooltio的展示隐藏
业务需要 需要改为 By clicking to control display hide

this.markersPlugin.__onMouseEnter = function () {
    // console.log('Cover the native method Change the trigger displaytoolTip方式为click')
    }
    this.markersPlugin.__onMouseLeave = function () {
    // console.log('Cover the native method Change the trigger displaytoolTip方式为click')
    }

// Selected annotation events
  this.markersPlugin.on('select-marker', this.selectMarker)

    selectMarker(e, marker) {
      // 选中标注 点击标注
      // console.log('选中标注 点击标注 select-marker e:', e)
      // console.log('marker:', marker)
      // If the last did not click edit to save 需要去掉
      this.cancelEdit()
      this.currentMarkerId = marker.id
      this.isEditMarker = true
      // currentTabIndex 1: 添加标注 2:添加跳转
      const { config } = e.args[0]
      console.log('标注 config:', config)

      if (config.type === 'jump') {
        // console.log('The selected is to add the jump labeling')
        // Corresponding annotation data update
        this.currentTabIndex = 2

        this.markersEditConfig.jump = {
          angle: config.angle,
          targetSceneId: config.targetSceneId // 目标场景id
        }
        // console.log('切换场景')
        // console.log('切换场景')
        // 编辑状态下 点击编辑  Preview or view Click to jump
        // this.setViewer(e.args[0].config.config.target)
      } else if (config.type === 'marker') {
        console.log('Show or hide the label')
        // Corresponding annotation data update
        this.currentTabIndex = 1
        this.markersEditConfig.marker.attachment = config.attachment || {}
        this.markersEditConfig.marker.title = config.title
        this.markersEditConfig.marker.description = config.description

        const visible = !!marker.config.tooltip.visible
        // 隐藏/展示tooltip内容
        const methods = visible ? 'hideTooltip' : 'showTooltip'
        // console.log('tooltipVisible:', visible)
        // console.log(
        //   'this.markersPlugin.markers[this.currentMarkerId]:',
        //   this.markersPlugin.markers[this.currentMarkerId]
        // )
        // 展示tooltip内容时 隐藏title 隐藏tooltip内容时 展示title
        this.markersPlugin.markers[
          this.currentMarkerId
        ].config.tooltip.visible = !visible
        this.markersPlugin.markers[this.currentMarkerId][methods]()
      }

      // console.log(
      //   'currentTabIndex 1: 添加标注 2:添加跳转  currentTabIndex:',
      //   this.currentTabIndex
      // )
    },
    
      this.viewer.on('click', (e, data) => {
        // Click on the panorama events
        const { target } = data
        // console.log('Click on the panorama')
        // console.log('e:', e)
        // console.log('data:', data)
        // console.log('target:', target)
        // console.log('target.parentNode:', target.parentNode)
        // console.log(target.parentNode.className)
        const targetClassName = target.className
        console.log('targetClassName:', targetClassName)
        if (typeof targetClassName === 'string') {
          // Attachment is pictures
          if (targetClassName.includes('imgToLeft')) {
            const scrollDom = this.$el.querySelector(
              '.marker-img-scroll-container'
            )
            scrollDom.scrollLeft -= 294
            return false
          }
          if (targetClassName.includes('imgToRight')) {
            const scrollDom = this.$el.querySelector(
              '.marker-img-scroll-container'
            )
            scrollDom.scrollLeft += 294

            return false
          }
          // The attachment for the video
          if (targetClassName.includes('videoToLeft')) {
            const scrollDom = this.$el.querySelector(
              '.marker-video-scroll-container'
            )
            scrollDom.scrollLeft -= 294
            return false
          }
          if (targetClassName.includes('videoToRight')) {
            const scrollDom = this.$el.querySelector(
              '.marker-video-scroll-container'
            )
            scrollDom.scrollLeft += 294

            return false
          }
          if (targetClassName === 'play-btn') {
            console.log('新建一个窗口 播放视频')
            console.log('target.dataset:', target.dataset)
            window.open(target.dataset.src)
            return false
          }
        }

        if (
          target.parentNode.className === 'psv-tooltip-content'
          || target.parentNode.parentNode.className === 'psv-tooltip-content'
          || target.parentNode.parentNode.parentNode.className
            === 'psv-tooltip-content'
          || target.parentNode.parentNode.parentNode.parentNode.className
            === 'psv-tooltip-content'
        ) {
          // Such a labeltooltipArea to click properly
          console.log('点击区域是marker-tooltip-container')

          return false
        }
        // If the last did not click edit to save 需要去掉
        this.cancelEdit()

        this.isEditMarker = true
        // To assign a value to default values
        this.markersEditConfig = {
          marker: {
            status: 0, // 0 未发布 1已发布
            title: '', // 标题
            description: '', // 描述
            attachment: {
              type: 'img', // 附件的类型 img video link
              imgArr: [],
              videoArr: [], // 视频
              linkText: '', // Text link text
              link: '' // 链接地址
            }
          },
          jump: {
            angle: '0°',
            targetSceneId: '' // 目标场景id
          }
        }
        // Add initial mark
        this.addMarker(e, data)
      }) 

unselect-marker(marker)

When a tag is selected and the user click on other place trigger.

推荐阅读

VueLearning source directory

VueSource learning complete directory

连点成线 - 前端成长之路

连点成线 - 前端成长之路


谢谢你阅读到了最后~
期待你关注、收藏、评论、点赞~
让我们一起 变得更强

`

先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在.深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小.自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前.因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担.添加下方名片,即可获取全套学习资料哦

原网站

版权声明
本文为[m0_67400972]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/214/202208021217299337.html