manage.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410
  1. //管理js文件 获取modeldata.js 判断是否有特殊的字段,如果有就先加载SpecialScene.js 里面有对特殊场景处理的代码 否则就直接加载main
  2. var Manage = function(){
  3. this.weixinURL = "https://res.wx.qq.com/open/js/jweixin-1.2.0.js",
  4. this.time = "?"+new Date().getTime();
  5. this.loadAudio();
  6. // this.loadWeixin();
  7. }
  8. //动态加载js文件
  9. Manage.prototype.LoadJs = function(_files, succes){
  10. /* 已加载文件缓存列表,用于判断文件是否已加载过,若已加载则不再次加载*/
  11. var classcodes = [];
  12. var FileArray = [];
  13. if (typeof _files === "object") {
  14. FileArray = _files;
  15. } else {
  16. /*如果文件列表是字符串,则用,切分成数组*/
  17. if (typeof _files === "string") {
  18. FileArray = _files.split(",");
  19. }
  20. }
  21. if (FileArray != null && FileArray.length > 0) {
  22. var LoadedCount = 0;
  23. for (var i = 0; i < FileArray.length; i++) {
  24. loadFile(FileArray[i], function() {
  25. LoadedCount++;
  26. if (LoadedCount == FileArray.length) {
  27. try {
  28. succes();
  29. }
  30. catch(err) {
  31. console.log("err: 您未定义回调");
  32. }
  33. }
  34. })
  35. }
  36. }
  37. /*加载JS文件,url:文件路径,success:加载成功回调函数*/
  38. function loadFile(url, success) {
  39. if (!FileIsExt(classcodes, url)) {
  40. var _ThisType = GetFileType(url);
  41. var ThisType = _ThisType.indexOf("?") == -1 ? _ThisType : _ThisType.substring(0,_ThisType.indexOf("?"));
  42. var fileObj = null;
  43. if (ThisType == ".js") {
  44. fileObj = document.createElement('script');
  45. fileObj.src = url;
  46. } else if (ThisType == ".css") {
  47. fileObj = document.createElement('link');
  48. fileObj.href = url;
  49. fileObj.type = "text/css";
  50. fileObj.rel = "stylesheet";
  51. } else if (ThisType == ".less") {
  52. fileObj = document.createElement('link');
  53. fileObj.href = url;
  54. fileObj.type = "text/css";
  55. fileObj.rel = "stylesheet/less";
  56. }
  57. success = success || function() {};
  58. fileObj.onload = fileObj.onreadystatechange = function() {
  59. if (!this.readyState || 'loaded' === this.readyState || 'complete' === this.readyState) {
  60. success();
  61. classcodes.push(url)
  62. }
  63. }
  64. document.getElementsByTagName('head')[0].appendChild(fileObj);
  65. } else {
  66. success();
  67. }
  68. }
  69. /*获取文件类型,后缀名,小写*/
  70. function GetFileType(url) {
  71. if (url != null && url.length > 0) {
  72. return url.substr(url.lastIndexOf(".")).toLowerCase();
  73. }
  74. return "";
  75. }
  76. /*文件是否已加载*/
  77. function FileIsExt(FileArray, _url) {
  78. if (FileArray != null && FileArray.length > 0) {
  79. var len = FileArray.length;
  80. for (var i = 0; i < len; i++) {
  81. if (FileArray[i] == _url) {
  82. return true;
  83. }
  84. }
  85. }
  86. return false;
  87. }
  88. };
  89. //获取页面url后面的参数
  90. Manage.prototype.number = function(variable) {
  91. var query = window.location.search.substring(1);
  92. var vars = query.split("&");
  93. for (var i=0;i<vars.length;i++) {
  94. var pair = vars[i].split("=");
  95. if(pair[0] == variable){return pair[1];}
  96. }
  97. return(false);
  98. };
  99. Manage.prototype.loadWeixin = function() {
  100. var that = this;
  101. this.LoadJs(that.weixinURL+that.time,function(){ });
  102. }
  103. Manage.prototype.loadAudio = function() { //相关:g_tourAudio \ g_playAudio
  104. g_bgAudio = new Audio;
  105. g_bgAudio.loop = true;
  106. g_bgAudio.autoplay = false;
  107. g_bgAudio.id = "bgaudio";
  108. g_bgAudio.volume = 0.4;
  109. //https://www.cnblogs.com/interdrp/p/4211883.html 部分资料
  110. g_bgAudio.load(); // iOS 9 还需要额外的 load 一下, 否则直接 play 无效
  111. var play = function(){
  112. //if(window.tourAudioSta) return;
  113. // this.switchBgmState(true)
  114. document.removeEventListener("touchstart",play);
  115. document.removeEventListener("click",play);
  116. $('#player').unbind("touchstart", play);
  117. }.bind(this);
  118. g_bgAudio.oncanplay = ()=>{
  119. // this.switchBgmState(true)
  120. }
  121. document.addEventListener("WeixinJSBridgeReady", ()=> {
  122. // this.switchBgmState(true)
  123. }, false);
  124. document.addEventListener("touchstart", play);//ios需要加个事件才能播放 不能自动播放;如果还有浏览器不行,换成别的交互事件
  125. document.addEventListener("click", play);
  126. $('#player').bind("touchstart", play);
  127. g_bgAudio.addEventListener('ended', ()=>{
  128. this.switchBgmState(true)
  129. });
  130. $("#volume").find("a").on("click", ()=> {
  131. if($("#volume img")[0].src.indexOf("btn_on.png")>-1)
  132. {
  133. this.switchBgmState(true);
  134. }
  135. else if($("#volume img")[0].src.indexOf("btn_off.png")>-1)
  136. {
  137. this.switchBgmState(false);
  138. }
  139. })
  140. }
  141. Manage.prototype.switchBgmState = function(state){
  142. if(!g_bgAudio || !g_bgAudio.src) return;
  143. var played = function(){
  144. console.log('begin play bgm');
  145. g_play = 1;
  146. g_playAudio = g_bgAudio;
  147. $("#volume a img").attr("src", "./static/images/Volume btn_off.png")
  148. $("#volume").attr("title", "关闭声音");
  149. g_tourAudio && g_tourAudio.pause()
  150. }
  151. var paused = function(){
  152. g_play = 0;
  153. g_playAudio == g_bgAudio && (g_playAudio = null)
  154. $("#volume a img").attr("src", "./static/images/Volume btn_on.png")
  155. $("#volume").attr("title", "打开声音");
  156. }
  157. if(state ){
  158. g_bgAudio.play();
  159. if(g_bgAudio.paused){
  160. paused()
  161. }else{
  162. played()
  163. return true
  164. }
  165. }else{
  166. g_bgAudio.pause();
  167. paused()
  168. }
  169. g_bgAudio.pauseByHot = false
  170. g_bgAudio.pauseByTour = false
  171. }
  172. Manage.prototype.weixinShare = function() {
  173. console.log("weixinShare")
  174. $.ajax({
  175. url: 'https://www.4dage.com/wechat/jssdk/share/',
  176. type: "post",
  177. data: {
  178. 'uri': location.href.split('#')[0], //当前页面地址
  179. 'name': "四维5号" //哪个公众号,对应上方的名称
  180. },
  181. dataType: "jsonp",
  182. jsonpCallback: "success_jsonp",
  183. success: function (data, textStatus) {
  184. wx.config({
  185. debug: false,
  186. appId: data.appId,
  187. timestamp: data.timestamp,
  188. nonceStr: data.nonceStr,
  189. signature: data.signature,
  190. jsApiList: ['checkJsApi', 'onMenuShareTimeline',
  191. 'onMenuShareAppMessage', 'onMenuShareQQ',
  192. 'onMenuShareWeibo']
  193. });
  194. },
  195. error: function (XMLHttpRequest, textStatus, errorThrown) {
  196. console.log("jsonp.error:" + textStatus);
  197. }
  198. });
  199. var success_jsonp = function(json){
  200. console.log(json);
  201. };
  202. wx.ready(function(){
  203. // config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行〿
  204. //对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中〿
  205. //分享到朋友圈
  206. console.log(g_weixinObj)
  207. wx.onMenuShareTimeline({
  208. title: g_weixinObj.title||'', // 分享标题
  209. link: g_weixinObj.lineLink||'', // 分享链接
  210. imgUrl: g_weixinObj.imgUrl||'', // 分享图标
  211. desc: g_weixinObj.desc||''
  212. });
  213. //获取“分享给朋友”按钮点击状态及自定义分享内容接叿
  214. wx.onMenuShareAppMessage({
  215. title: g_weixinObj.title, // 分享标题
  216. desc: g_weixinObj.desc, // 分享描述
  217. link: g_weixinObj.lineLink, // 分享链接
  218. imgUrl: g_weixinObj.imgUrl, // 分享图标
  219. type: '', // 分享类型,music、video或link,不填默认为link
  220. dataUrl: '' // 如果type是music或video,则要提供数据链接,默认为空
  221. });
  222. wx.onMenuShareWeibo({
  223. title: g_weixinObj.title, // 分享标题
  224. desc: g_weixinObj.desc, // 分享描述
  225. link: g_weixinObj.lineLink, // 分享链接
  226. imgUrl: g_weixinObj.imgUrl, // 分享图标
  227. success: function () {
  228. // 用户确认分享后执行的回调函数
  229. },
  230. cancel: function () {
  231. // 用户取消分享后执行的回调函数
  232. }
  233. });
  234. wx.onMenuShareQZone({
  235. title: g_weixinObj.title, // 分享标题
  236. desc: g_weixinObj.desc, // 分享描述
  237. link: g_weixinObj.lineLink, // 分享链接
  238. imgUrl: g_weixinObj.imgUrl, // 分享图标
  239. success: function () {
  240. // 用户确认分享后执行的回调函数
  241. },
  242. cancel: function () {
  243. // 用户取消分享后执行的回调函数
  244. }
  245. });
  246. wx.onMenuShareQQ({
  247. title: g_weixinObj.title, // 分享标题
  248. desc: g_weixinObj.desc, // 分享描述
  249. link: g_weixinObj.lineLink, // 分享链接
  250. imgUrl: g_weixinObj.imgUrl, // 分享图标
  251. success: function () {
  252. // 用户确认分享后执行的回调函数
  253. },
  254. cancel: function () {
  255. // 用户取消分享后执行的回调函数
  256. }
  257. });
  258. wx.error(function(res){
  259. // config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名〿
  260. });
  261. });
  262. }
  263. Manage.prototype.dealURL = function(src, type){
  264. //music: "///super.4dage.com/data/LYW/edit/20200928_151633415.mp3"
  265. //"https://super.4dage.com/data/LYW/edit/20200928_165319399.jpg"]
  266. if(window.isLocal && settings.localPrefix!=void 0){//本地将线上的前缀替换
  267. var oldPrefixs = ["https://super.4dage.com/", "http://super.4dage.com/", "///super.4dage.com/"]
  268. for(let i=0;i<oldPrefixs.length;i++){
  269. if(src.includes(oldPrefixs[i])){
  270. return src.replace(oldPrefixs[i], settings.localPrefix)
  271. break;
  272. }
  273. }
  274. console.error("没有找到合适的本地链接")
  275. return src
  276. }else{
  277. return src
  278. }
  279. }
  280. var manage = new Manage();
  281. //公用的函数
  282. function getQueryVariable(variable)
  283. {
  284. var query = window.location.search.substring(1);
  285. var vars = query.split("&");
  286. for (var i=0;i<vars.length;i++) {
  287. var pair = vars[i].split("=");
  288. if(pair[0] == variable){return pair[1];}
  289. }
  290. return(false);
  291. }
  292. //隐藏公司Logo
  293. function showLogo(){
  294. $("#myCompany").hide();
  295. $("#loaderCoBrandName").hide();
  296. $("#title-logo").hide();
  297. $(".title-container").css("justify-content","center")
  298. }
  299. //czj 添加随机的时间
  300. function randomTime(){
  301. return new Date()
  302. }
  303. function matcher(data){
  304. if(!data || !g_version ) return data;
  305. delete data.model.vision_version;
  306. var _data = {
  307. files: {
  308. "templates": ["images/images{{number}}/{{filename}}"]
  309. },
  310. model :{
  311. sid :window.number,
  312. camera_start:
  313. data.model.images && data.model.images.length != 0 ?
  314. {
  315. camera: {
  316. zoom: "-1",
  317. quaternion: [
  318. JSON.parse(data.model.images[0].metadata).camera_quaternion.z,
  319. JSON.parse(data.model.images[0].metadata).camera_quaternion.w,
  320. JSON.parse(data.model.images[0].metadata).camera_quaternion.x,
  321. JSON.parse(data.model.images[0].metadata).camera_quaternion.y
  322. ]
  323. },
  324. pano: { uuid: JSON.parse(data.model.images[0].metadata).scan_id },
  325. mode: "0"
  326. }
  327. : ''
  328. },
  329. sid: window.number,
  330. hoticon: {
  331. default: "https://super.4dage.com/images/4dagePoint2.png",
  332. higt: "https://super.4dage.com/images/4dagePoint.png"
  333. },
  334. special: "false",
  335. weixinDesc: ""
  336. };
  337. $.extend(true,data,_data)
  338. return data;
  339. }
  340. function hotMatcher(data){
  341. if(!data || !g_version) return data;
  342. data.tourAudio = data.audio;
  343. return data;
  344. }
  345. //兼容一代的場景
  346. //請求地址統一管理
  347. var g_onePregix = "https://bigscene.4dage.com/" //对应一代 http://www.4dmodel.com/SuperPanoramic/index.html?m=55
  348. var g_version = manage.number("version");
  349. g_version === "one" ? g_Prefix = g_onePregix : '';