位置: IT常识 - 正文

photo-sphere-viewer中文文档

编辑:rootadmin
photo-sphere-viewer中文文档 photo-sphere-viewer中文文档安装插件Configuration 配置项Standard options 常规配置container (required)adapter 适配器panorama (required)plugins 插件caption 标题size 全景图宽度高度markers 标注navbar 导航栏minFovmaxFovdefaultZoomLvlfisheyedefaultLongdefaultLatlongitudeRangelatitudeRangeautorotateDelayautorotateSpeedautorotateLatlangloadingImgloadingTxtmousewheelmousemovemousewheelCtrlKeycaptureCursortouchmoveTwoFingersAdvanced options 高级选项sphereCorrection 球面校正moveSpeedzoomSpeeduseXmpDatapanoData 全景数据requestHeaderscanvasBackgroundmoveInertiaclickEventOnMarkerwithCredentialskeyboard 键盘Viewer Methods方法常用方法初始化全景图animate(options): Animationdestroy()getPosition(): PositiongetZoomLevel(): numberrotate(position)setOption(option, value)setOptions(options)setPanorama(panorama, options): Promisezoom(level) | zoomIn() | zoomOut()Events 事件常用事件初始化全景图全景图点击事件 click(data) | dblclick(data)全景图位置变化时触发的回调 position-updated(position)全景图加载完成时的回调 ready全景图缩放时的回调 zoom-updated(level)MarkersPlugin 标注插件用法标注定义标注配置项id (required)x & y or latitude & longitude (required)width & height (required for images, recommended for html)scaleclassNamestylesvgStyleanchorvisibletooltipcontenthideListdataConfigurationlanghideButtonlistButtonclickEventOnMarker标注常用方法添加标注 addMarker(properties)清除所有标注 clearMarkers()获取当前标注 getCurrentMarker(): Marker前往指定标注 gotoMarker(id, speed): Animation隐藏/显示 标注 hideMarker(id) | showMarker(id) | toggleMarker(id)removeMarker(id) | removeMarkers(ids)替换标注 setMarkers(properties[])更新标注 updateMarker(properties)标记事件over-marker(marker) | leave-marker(marker)select-marker(marker, data)unselect-marker(marker)推荐阅读Vue源码学习目录连点成线 - 前端成长之路

推荐整理分享photo-sphere-viewer中文文档,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

你越是认真生活,你的生活就会越美好!

业务这边想要实现右边链接的效果阿里云付费全景图,类似VR看房,支持360° x 360°任意旋转,支持自定义添加标注,支持切换场景等功能,效果如下

阿里云的全景图需要付费,而且个别功能不满足我们业务需要,那边无法及时调整,所以后面由我们内部自己实现

前端组长这边提供了 photo-sphere-viewer 相关的文章作为参考

内部基于 photo-sphere-viewer 插件实现效果如下

全景图实现使用了 photo-sphere-viewer 插件,它基于three.js和uEvent 2实现

这边实现主要用了 photo-sphere-viewer和他的标记Markers插件

安装插件

使用 npm 或 yarn 下载安装

npm install photo-sphere-viewer --saveyarn 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 配置项

一个陌生的对象,打断点后,去控制台查看,可以很方便看到对象的属性方法之类的信息

Standard options 常规配置container (required)type: HTMLElement | string

全景图的容器,可以是DOM元素或者DOM的ID

container: document.querySelector('.viewer')container: 'viewer' // will target [id="viewer"]adapter 适配器default: equirectangular

用于加载全景图的适配器

panorama (required)type: *

全景图地址,如果用默认的适配器,只支持传单个

plugins 插件type: array

Introduction to plugins 这里只用到标注插件,后面单独介绍

caption 标题type: string

导航栏中显示的文本。如果导航栏被禁用,它无论如何都会显示,但没有按钮。允许使用 HTML

size 全景图宽度高度type: { width: integer, height: integer }

全景容器的最终尺寸。默认情况下使用容器的大小,并在窗口调整大小期间遵循

markers 标注

标注的配置

navbar 导航栏

导航栏的配置

minFovtype: integerdefault: 30

最小视野(对应于最大缩放),介于 1 和 179 之间。

maxFovtype: integerdefault: 90

最大视野(对应于最小缩放),介于 1 和 179 之间

defaultZoomLvltype: integerdefault: 50

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

fisheyetype: boolean | doubledefault: false

使用 true 启用鱼眼效果或指定效果强度 (true = 1.0)。

PS: 此模式可能会对标记渲染产生副作用

defaultLongtype: double | stringdefault: 0 初始经度,介于 0 和 2π 之间defaultLattype: double | stringdefault: 0 初始纬度,介于 -π/2 和 π/2 之间。longitudeRange

插件VisibleRangePlugin

latitudeRange

插件VisibleRangePlugin

autorotateDelaytype: integerdefault: null

自动旋转开始后的延迟,以毫秒为单位

autorotateSpeedtype: stringdefault: 2rpm

自动旋转速度

autorotateLattype: double | stringdefault: defaultLat

执行自动旋转的纬度

langtype: 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',}

查看器中使用的各种文本

loadingImgtype: string

显示在加载圆圈中心的图像的路径,也就是loading图

loadingTxttype: stringdefault: ‘Loading…’

加载圈中心显示的文本,仅在未提供loadingImg时使用

mousewheeltype: booleandefault: true

使用鼠标滚轮启用缩放,缩放过程会隐藏标注里的tooltip内容

mousemovetype: booleandefault: true

使用鼠标光标或手指在触摸屏上滑动启用全景旋转

mousewheelCtrlKeytype: booleandefault: false

需要使用 ctrl 键来缩放全景图。允许在不干扰查看器的情况下滚动页面。如果启用,当没有按下 ctrl 键时,会显示要求用户使用 ctrl + 滚动的覆盖图

captureCursortype: booleandefault: false

只需将光标移动到视图上方而不是单击+移动即可旋转全景图

touchmoveTwoFingerstype: booleandefault: false

需要两个手指来旋转全景。这允许在包含查看器的页面中进行标准的触摸滚动导航。如果启用,当仅检测到一次触摸时,会显示要求用户使用两根手指的覆盖图

Advanced options 高级选项

业务开发过程,还没用到

sphereCorrection 球面校正type: { pan: double, tilt: double, roll: double }default: { pan:0, tilt:0, roll: 0 }

球体旋转角度,以弧度为单位。

PS: 如果 XMP 数据和/或 panoData 包含航向/俯仰/滚动数据,它们将在 sphereCorrection 之前应用

moveSpeedtype: doubledefault 1

全景移动的速度倍增器。用于单击移动、触摸移动和导航栏按钮。

zoomSpeedtype: doubledefault 1

用于全景变焦的速度倍增器。用于鼠标滚轮、触摸捏合和导航栏按钮。

useXmpDatatype: booleandefault true

从 XMP 数据中读取真实图像大小,如果全景拍摄后已裁剪,则必须保持真实

panoData 全景数据type: object | function<Image, object>

覆盖在全景文件中找到的 XMP 数据(或者在 useXmpData=false 时简单地定义它)。所有参数都是可选的。

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}

它也可以是根据加载的图像动态计算裁剪配置的函数。

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 包含航向/俯仰/滚动数据,它们将在 sphereCorrection 之前应用

requestHeaderstype: object | function<string, object>

加载图像文件时设置 HTTP 请求头。

requestHeaders: { header: value,}

它也可以是在每次调用之前动态设置请求头的函数。这在向 Authorization 标头添加临时有效的 Bearer 时很有用。

requestHeaders: (url) => ({ header: value,})canvasBackgroundtype: stringdefault: #000

画布的背景,在使用裁剪的全景图时可见

moveInertiatype: booleandefault: true

手动移动后启用平滑动画

clickEventOnMarker

插件MarkersPlugin,后面会介绍

withCredentialstype: booleandefault: falsephoto-sphere-viewer中文文档

对 HTTP 请求使用凭据。

keyboard 键盘type: boolean | objectdefault:keyboard: { 'ArrowUp': 'rotateLatitudeUp', 'ArrowDown': 'rotateLatitudeDown', 'ArrowRight': 'rotateLongitudeRight', 'ArrowLeft': 'rotateLongitudeLeft', 'PageUp': 'zoomIn', 'PageDown': 'zoomOut', '+': 'zoomIn', '-': 'zoomOut', ' ': 'toggleAutorotate'}

启用和配置全屏键盘导航。它是一个定义键代码->动作的映射。设置为 false 以禁用。 (上面列出了所有可用的操作)

Viewer Methods方法

许多方法可用于从您的应用程序控制Viewer。 API 文档中提供了完整的方法列表

在调用任何方法之前等待Viewer就绪事件是一种很好的做法。

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

这里仅列出常用的方法,完整的方法列表可以看 API 文档。

初始化全景图import { Viewer } from 'photo-sphere-viewer'import 'photo-sphere-viewer/dist/photo-sphere-viewer.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%' }})animate(options): Animation

使用流畅的动画旋转和缩放视图。可以更改位置(经度、纬度或 x、y)和缩放级别(缩放)。

速度选项是以毫秒为单位的持续时间或包含以每分钟转数 (2rpm) 或每秒度数 (10dps) 为单位的速度的字符串。

它返回一个 PSV.Animation,它是一个带有附加取消方法的标准 Promise。

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

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

Vue项目中,切换全景图时,需要先卸载当前的全景图

// 切换场景的话 先销毁原来的场景// 有时候this.viewer.destroy()执行会报错 如果报错 这里手动remove掉对应的元素 if (this.viewer) try { this.viewer.destroy() } catch (e) { console.log(e) const viewer = document.querySelector('#viewer') viewer.removeChild(viewer.childNodes[0]) }getPosition(): Position

返回视图的当前位置

getZoomLevel(): number

返回 0 到 100 之间的当前缩放级别

rotate(position)

立即旋转没有动画的视图。

// you can also use longitude and latitudeviewer.rotate({ x: 1500, y: 600,});setOption(option, value)

更新查看器的选项。某些选项无法更改:全景、全景数据、容器、适配器和插件

viewer.setOption('fisheye', true);setOptions(options)

一次更新多个选项。

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

使用可选的过渡动画(默认启用)更改全景图像。如果需要,您还可以设置新的 sphereCorrection 和 panoData

viewer.setPanorama('image.jpg') .then(() => /* update complete */);zoom(level) | zoomIn() | zoomOut()

在没有动画的情况下更改缩放级别。

Events 事件

Photo Sphere Viewer使用uEvent API,API 文档中提供了完整的事件列表

事件监听器以一个 Event 对象作为第一个参数,这个对象一般不使用。在此事件对象之后可以使用其他参数。

常用事件

本节描述了常用的事件,请记得查看 API 文档以获取完整列表

初始化全景图import { Viewer } from 'photo-sphere-viewer'import 'photo-sphere-viewer/dist/photo-sphere-viewer.css'// 初始化全景图this.viewer = new Viewer({ container: document.querySelector('#viewer'), panorama, // 全景图地址 size: { width: '100%', height: '100%' }})全景图点击事件 click(data) | dblclick(data)

当用户点击查看器(除了导航栏和侧面板之外的所有地方)时触发,它包含许多关于用户点击位置的信息,如果启用了 clickEventOnMarker 选项,则包括一个标记。

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

点击事件总是在 dblclick 之前触发

Vue项目中使用

this.viewer.on('click', (e, data) => { // 点击全景图事件 console.log('e:', e) console.log('data:', data)}

全景图位置变化时触发的回调 position-updated(position)

当视图经度和/或纬度改变时触发。

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

Vue项目使用如下

this.viewer.on('position-updated', (e, position) => { console.log({ e }) console.log({ position }) // 全景图位置变化时 也就是旋转时会把显示的标注tooltip内容隐藏 这里停止旋转时 让这部分标注tooltip重新展示 // config.tooltip?.visible是手动添加的变量 用来判断标注的tooltip是否显示 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) })

全景图加载完成时的回调 ready

当全景图像已加载且Viewer已准备好执行第一次渲染时触发。

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

项目中在ready后会获取标注数据,生成标注

this.viewer.once('ready', () => { // 去掉首屏loading this.fullLoading = false // 初始化标注 this.initMarkers() // 自动水平旋转 // this.viewer.startAutorotate() })全景图缩放时的回调 zoom-updated(level)viewer.on('zoom-updated', (e, level) => { console.log(`new zoom level is ${level}`);});MarkersPlugin 标注插件

在查看器上显示各种标记/热点。API文档

该插件文件位于photo-sphere-viewer依赖包的dist/plugins/markers.js和 dist/plugins/markers.css。

用法

该插件提供了一个强大的标记系统,允许使用可选的工具提示和描述定义全景图上的兴趣点。标记可以动态添加/删除,您可以对用户点击/点击做出反应。

有四种类型的标记

使用 html 属性定义的 HTML使用 image 属性定义的图像使用 rect、circle、ellipse 或 path 属性定义的 SVG

可以在初始化全景图时使用标记选项或在加载后使用各种方法添加标记。

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":"\n <div class=\"marker-tooltip-container\">\n <div class=\"marker-img-continaer\">\n \n <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>\n <img class=\"btn toLeft imgToLeft\" src=>\n <img class=\"btn toRight imgToRight\" src=>\n </div>\n <p class=\"marker-title\">\n 图片test\n </p>\n <p class=\"marker-description\" style=display:none;>\n \n </p>\n </div>\n ", "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

markers对象里的每一个属性都是一个标注,key值是标注的id

标注的配置重点关注html和tooltip属性,这里都用了html字符串,这样方便自定义,样式和交互,

除了下面表格的属性,其他的是自定义的,用来存编辑的数据,然后生成html和tooltip字段的内容

标注定义

一个标注至少得有下面一个配置

NameTypeDescriptionimagestring表示标记的图像的路径。需要定义宽度和高度。 htmlstring标记的 HTML 内容。建议定义宽度和高度。squareinteger正方形的大小rectinteger[2] |{width:int,height:int}长方形的大小circleinteger圆的半径ellipseinteger[2] |{cx:int,cy:int}椭圆的半径。pathstring路径的定义(0,0 将放置在定义的 x/y 或经度/纬度处)。polygonPxinteger[2][]在全景图像上的像素坐标中定义多边形的点数组。polygonRaddouble[2][]同上,但坐标是经度和纬度。polylinePxinteger[2][]与polygonPx 相同,但生成多段线。polylineRaddouble[2][]与polygonRad 相同,但生成多段线。

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:纹理坐标不适用于立方体贴图。

标注配置项id (required)type: string

标记的唯一标识符。

x & y or latitude & longitude (required)type: integer or double

标记在纹理坐标(像素)或球坐标(弧度)中的位置。 (多边形和折线忽略此选项)

width & height (required for images, recommended for html)type: integer

标记的大小。 (多边形和折线忽略此选项)

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

根据缩放级别和/或经度偏移配置标记的比例。这旨在在用户缩放和移动时为标记的大小提供自然的感觉。 (多边形和折线忽略此选项)

根据缩放级别缩放,数组包含[以最小缩放比例缩放,以最大缩放比例缩放]

scale: { // 标记在最小缩放级别上小两倍 zoom: [0.5, 1]}// same thingscale: [0.5, 1]

根据位置缩放,数组包含 [中心缩放,侧面缩放]:

scale: { // 标记在屏幕一侧时大两倍 longitude: [1, 2]}

两种配置可以组合使用

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

添加到标记元素的类名。

styletype: object

要在标记上设置的 CSS 属性(背景、边框等)。

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

要在标记上设置的 SVG 属性(填充、描边等)。仅适用于 SVG 和多边形/折线标记。

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

图像和图案背景

可以使用模式定义来定义复杂的 SVG 背景,例如图像。

首先在页面中的某处

本文链接地址:https://www.jiuchutong.com/zhishi/299119.html 转载请保留说明!

上一篇:初识React及React开发依赖介绍(react基础入门)

下一篇:uniapp实现上拉加载更多(uniapp下拉)

  • 收到个税返还手续费怎么算增值税附加
  • 总公司是小规模分公司是一般纳税人
  • 预缴增值税是否要预缴企业所得税
  • 小规模纳税人合理避税
  • 什么是特别纳税人
  • 企业重组的特殊性税务处理比例
  • 城建税的计税依据是增值税和消费税的和吗
  • 以前年度损益对应的科目
  • 太阳能发电开票编码
  • 联营企业属于企业吗
  • 折旧费计算主要有几种方法?分别有什么特点?
  • 删除申报记录什么意思
  • 研发支出资本化支出在报表哪里
  • 发票代码有误什么意思
  • 增值税普通发票怎么开
  • 本金加收入减支出等于的是利润吗
  • 融资租赁的长期投资包括
  • 行政事业单位核算的应交税费包括
  • 银行手续费发票怎么开
  • 出口退税没有进项就退不了税吗?
  • 国家金库是什么税费
  • 质量问题扣款账务处理
  • 企业购进口汽车会计分录
  • 对外报价时应考虑哪些因素
  • 税务局每年都会查我公司虚开发票
  • 280服务费抵税分录
  • 滞留票的进项税能抵扣吗
  • 国税发2005 9号 税屋
  • 业务招待费在企业所得税税前扣除的标准是什么?
  • 分公司可以单独签协议吗
  • 电子公章盖上去怎么文字看不到了
  • 收回税款 会计分录
  • 公共基础设施折旧年限表 20
  • 企业筹建期间可以自己发农民工工资么
  • 计提代扣代缴个税
  • thinkphp怎么用
  • macbookpro常见问题
  • 其他应付款余额在借方表示什么意思
  • 使用二氧化碳灭火器时人应该站在什么位置
  • 比利时的平菇能吃吗
  • 金碟软件如何查看明细账
  • 企业残保金怎样申报
  • 【第三趴】uni-app页面搭建与路由配置(了解工程目录结构、学会搭建页面、配置路由并成功运行)
  • springboot jni
  • 设置cmd命令
  • 免征和抵扣税额的区别
  • 13个点的普票可以抵税吗
  • 个人独资企业法人可以发工资吗
  • 支付资金占用费的承诺函怎么写
  • 开出地税发票(工程款)怎么做账?
  • 建筑公司脚手架租赁费会计分录
  • 农民专业合作社属于什么经济类型
  • 预缴的附加税月末结转吗
  • 支付残疾人保证金的现金流
  • 收到客户提供代付发票
  • 月报报表格式
  • 会计成本核算方法有几种类型
  • 金融企业借款费用计入
  • sql server修改数据表
  • fedora31安装教程
  • mac怎么一键关机
  • macbookair如何隐藏文件
  • 如何解决焦虑的心理
  • 文件选项夹在哪里
  • win10系统edge浏览器兼容性
  • win7系统的wlan在哪里?
  • linux命令存放在哪里
  • 安卓框架app
  • awk实现wc功能
  • 备份mbr引导
  • Node.js中的什么模块是用于处理文件和目录的
  • python回归结果输出
  • python2与python3的区别
  • node.js 配置
  • linearlayout布局怎么设置
  • javascript要怎么学
  • android应用程序的主要语言是
  • 关于使用RequestWindowFeature为啥一定要在setContentView之前调用
  • tiny rails汉化
  • 国家税务局公告2018年第28号
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设