vtourskin.xml 61 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334
  1. <krpano>
  2. <!-- krpano 1.20.9 - Virtual Tour Skin -->
  3. <!-- skin settings (can be overridden in the tour.xml) -->
  4. <skin_settings maps="false"
  5. maps_type="google"
  6. maps_bing_api_key=""
  7. maps_google_api_key=""
  8. maps_zoombuttons="false"
  9. maps_loadonfirstuse="true"
  10. gyro="true"
  11. gyro_keeplookingdirection="false"
  12. webvr="true"
  13. webvr_keeplookingdirection="true"
  14. webvr_prev_next_hotspots="true"
  15. autotour="false"
  16. littleplanetintro="false"
  17. followmousecontrol="false"
  18. title="true"
  19. thumbs="true"
  20. thumbs_width="120" thumbs_height="80" thumbs_padding="10" thumbs_crop="0|40|240|160"
  21. thumbs_opened="false"
  22. thumbs_text="false"
  23. thumbs_dragging="true"
  24. thumbs_onhoverscrolling="false"
  25. thumbs_scrollbuttons="false"
  26. thumbs_scrollindicator="false"
  27. thumbs_loop="false"
  28. tooltips_buttons="false"
  29. tooltips_thumbs="false"
  30. tooltips_hotspots="false"
  31. tooltips_mapspots="false"
  32. deeplinking="false"
  33. loadscene_flags="MERGE"
  34. loadscene_blend="OPENBLEND(0.5, 0.0, 0.75, 0.05, linear)"
  35. loadscene_blend_prev="SLIDEBLEND(0.5, 180, 0.75, linear)"
  36. loadscene_blend_next="SLIDEBLEND(0.5, 0, 0.75, linear)"
  37. loadingtext=""
  38. layout_width="100%"
  39. layout_maxwidth="814"
  40. controlbar_width="-24"
  41. controlbar_height="40"
  42. controlbar_offset="20"
  43. controlbar_offset_closed="-40"
  44. controlbar_overlap.no-fractionalscaling="10"
  45. controlbar_overlap.fractionalscaling="0"
  46. design_skin_images="vtourskin.png"
  47. design_bgcolor="0x2D3E50"
  48. design_bgalpha="0.8"
  49. design_bgborder="0"
  50. design_bgroundedge="1"
  51. design_bgshadow="0 4 10 0x000000 0.3"
  52. design_thumbborder_bgborder="3 0xFFFFFF 1.0"
  53. design_thumbborder_padding="2"
  54. design_thumbborder_bgroundedge="0"
  55. design_text_css="color:#FFFFFF; font-family:Arial;"
  56. design_text_shadow="1"
  57. />
  58. <!-- save the url path of this xml file (the url value will be adjusted during xml parsing) -->
  59. <vtourskinxmlpath url="./" />
  60. <!-- iPhone X safe-area support: use the horizontal safe-area only -->
  61. <display safearea="h-only" />
  62. <!-- mouse / touch / keyboard(button) control settings - https://krpano.com/docu/xml/#control -->
  63. <control mouse="drag"
  64. touch="drag"
  65. zoomtocursor="false"
  66. zoomoutcursor="false"
  67. draginertia="0.1"
  68. dragfriction="0.9"
  69. movetoaccelerate="1.0"
  70. movetospeed="10.0"
  71. movetofriction="0.8"
  72. keybaccelerate="0.09"
  73. keybfriction="0.94"
  74. keybfovchange="0.25"
  75. mousefovchange="1.0"
  76. fovspeed="3.0"
  77. fovfriction="0.9"
  78. bouncinglimits="true"
  79. />
  80. <!-- mouse cursors - https://krpano.com/docu/xml/#cursors -->
  81. <cursors standard="default"
  82. dragging="move"
  83. moving="move"
  84. />
  85. <!-- ensure stagescale 2x for mobile devices (regardless if mobilescale is 0.5 or 1.0) -->
  86. <krpano stagescale="calc:stagescale * 2" if="stagescale LT 1.0" devices="mobile" />
  87. <!-- VR support - https://krpano.com/plugins/webvr/ -->
  88. <include url="%VIEWER%/plugins/webvr.xml" devices="html5" />
  89. <!-- overwrite some settings from the webvr.xml for the skin integration -->
  90. <plugin name="webvr" keep="true" devices="html5.and.webgl"
  91. url="calc:skin_settings.webvr == true ? '%VIEWER%/plugins/webvr.js' : null"
  92. onavailable="skin_webvr_onavailable();"
  93. onentervr="skin_showloading(false); webvr_onentervr(); skin_webvr_setup(); skin_reloadscene_webvr();"
  94. onexitvr="webvr_onexitvr(); skin_webvr_setup(); skin_reloadscene_webvr();"
  95. />
  96. <!-- webvr button style (adjust to match skin style) -->
  97. <style name="webvr_button_style"
  98. bgroundedge="calc:skin_settings.design_bgroundedge"
  99. bgcolor="get:skin_settings.design_bgcolor" bgalpha="get:skin_settings.design_bgalpha"
  100. bgborder="get:skin_settings.design_bgborder"
  101. bgshadow="get:skin_settings.design_bgshadow"
  102. css="calc:skin_settings.design_text_css + ' font-size:' + 20*webvr_setup_scale*webvr_button_scale + 'px;'"
  103. />
  104. <!-- show a 'rotate the device' info when the mobile device is in portrait orientation in VR mode -->
  105. <layer name="webvr_rotate_to_landscape_request" keep="true" vr="true" devices="mobile"
  106. url="rotate_device.png" scale="0.5"
  107. align="top" edge="center" y="28%"
  108. autoalpha="true" alpha="0.0"
  109. enabled="false"
  110. />
  111. <events name="skin_webvr_and_gyro_events" keep="true" devices="html5"
  112. onxmlcomplete="skin_set_webvr_or_gyro_startup_view()"
  113. onresize.mobile="skin_webvr_act_as_gyro_in_portrait_mode();"
  114. onloadcomplete="delayedcall(0.5, if(webvr.isenabled AND scene.count GT 1 AND skin_settings.webvr_prev_next_hotspots, set(hotspot[skin_webvr_prev_scene].visible,true); set(hotspot[skin_webvr_next_scene].visible,true); ); );"
  115. onviewchange=""
  116. />
  117. <action name="skin_webvr_onavailable" scope="local">
  118. if(webvr.isvrbrowser,
  119. <!-- show a special enter VR screen for Gear VR browsers (Oculus Browser or Samsung Internet VR) -->
  120. set(layer[webvr_enterbutton],
  121. align=center, y=0, padding='10 20',
  122. css=calc(skin_settings.design_text_css + ' font-size:20px;text-align:center;'),
  123. html=calc((global.title ? '[i]'+global.title+'[/i][br]' : '') + '[span style="font-size:40px"]Enter VR[span]'),
  124. );
  125. skin_hideskin(instant);
  126. ,
  127. <!-- remove the enter vr button from the webvr.xml -->
  128. removelayer(webvr_enterbutton);
  129. );
  130. <!-- update the skin buttons to add the skin vr button -->
  131. skin_arrange_buttons();
  132. <!-- call the original onavailable event from the webvr.xml -->
  133. webvr_onavailable();
  134. </action>
  135. <action name="skin_set_webvr_or_gyro_startup_view">
  136. if( (webvr.isenabled == true AND skin_settings.webvr_keeplookingdirection == false) OR (!webvr.isenabled AND plugin[skin_gyro].enabled == true AND skin_settings.gyro_keeplookingdirection == false),
  137. skin_lookat( get(xml.view.hlookat) );
  138. );
  139. </action>
  140. <action name="skin_webvr_setup">
  141. if(webvr.isenabled,
  142. copy(skin_settings.loadscene_flags_backup, skin_settings.loadscene_flags);
  143. set(skin_settings.loadscene_flags, MERGE|KEEPVIEW|KEEPMOVING|NOPREVIEW);
  144. skin_webvr_act_as_gyro_in_portrait_mode(true);
  145. if(scene.count GT 1 AND skin_settings.webvr_prev_next_hotspots,
  146. set(hotspot[skin_webvr_prev_scene].visible, true);
  147. set(hotspot[skin_webvr_next_scene].visible, true);
  148. set(events[skin_webvr_and_gyro_events].onviewchange, skin_webvr_menu_following());
  149. );
  150. ,
  151. if(skin_settings.loadscene_flags_backup !== null, copy(skin_settings.loadscene_flags, skin_settings.loadscene_flags_backup); );
  152. if(layer[webvr_rotate_to_landscape_request], tween(layer[webvr_rotate_to_landscape_request].alpha, 0.0, 0.0); );
  153. set(hotspot[skin_webvr_prev_scene].visible, false);
  154. set(hotspot[skin_webvr_next_scene].visible, false);
  155. set(events[skin_webvr_and_gyro_events].onviewchange, null);
  156. );
  157. </action>
  158. <action name="skin_webvr_act_as_gyro_in_portrait_mode" scope="local" args="setupcall">
  159. if(device.mobile AND webvr.isenabled,
  160. div(aspect, stagewidth, stageheight);
  161. if(aspect != lastaspect OR setupcall == true,
  162. copy(lastaspect, aspect);
  163. if(stagewidth GT stageheight,
  164. <!-- landscape orientation - use stereo rendering and a direct/fast gyro sensor mode -->
  165. set(display.stereo, true);
  166. set(webvr.mobilevr_sensor_mode, 3);
  167. webvr.update();
  168. tween(layer[webvr_rotate_to_landscape_request].alpha, 0.0, 0.0);
  169. ,
  170. <!-- portrait orientation - use normal rendering and a smoother/slower gyro sensor mode -->
  171. set(display.stereo, false);
  172. set(webvr.mobilevr_sensor_mode, 1);
  173. webvr.update();
  174. tween(layer[webvr_rotate_to_landscape_request].alpha, 1.0);
  175. delayedcall(3.0, tween(layer[webvr_rotate_to_landscape_request].alpha, 0.0, 1.0); );
  176. );
  177. );
  178. ,
  179. set(lastaspect, 0);
  180. );
  181. </action>
  182. <!-- VR scene switching hotspots -->
  183. <style name="skin_webvr_menu_style" torigin="view" depth="1000" scale="0.625" distorted="true" ath="0" atv="45" alpha="0.5" />
  184. <hotspot name="skin_webvr_prev_scene" keep="true" style="skin_base|skin_webvr_menu_style" crop="0|64|64|64" ox="-88" onover="tween(scale,0.750);" onout="tween(scale,0.625);" vr_timeout="750" onclick="skin_nextscene_loop(-1);" visible="false" devices="html5.and.webgl" />
  185. <hotspot name="skin_webvr_next_scene" keep="true" style="skin_base|skin_webvr_menu_style" crop="64|64|64|64" ox="+88" onover="tween(scale,0.750);" onout="tween(scale,0.625);" vr_timeout="750" onclick="skin_nextscene_loop(+1);" visible="false" devices="html5.and.webgl" />
  186. <!-- floating/following VR hotspots -->
  187. <action name="skin_webvr_menu_following" type="Javascript" devices="html5"><![CDATA[
  188. var hs1 = krpano.get("hotspot[skin_webvr_prev_scene]");
  189. var hs2 = krpano.get("hotspot[skin_webvr_next_scene]");
  190. if(!hs1.hovering && !hs2.hovering)
  191. {
  192. var f = 0.01; // following speed factor
  193. var h = krpano.view.hlookat;
  194. var v = krpano.view.vlookat;
  195. var hsh = hs1.ath;
  196. var hsv = hs1.atv;
  197. h = (h -(h|0)) + (((h|0) +360180)%360) - 180.0;
  198. v = (v -(v|0)) + (((v|0) +360180)%360) - 180.0;
  199. hsh = (hsh-(hsh|0)) + (((hsh|0)+360180)%360) - 180.0;
  200. var dh = h - hsh;
  201. dh += (dh > 180) ? -360 : (dh < -180) ? 360 : 0
  202. hsh += dh*f;
  203. var a = Math.abs(v - hsv) / 90.0;
  204. a = 1.0 * Math.max(1.0 - 2.0*Math.sqrt(a), 0);
  205. v = v + 55.0 - v*1.5;
  206. hsv = hsv*(1.0 - f) + v*f;
  207. hs1.ath = hs2.ath = hsh;
  208. hs1.atv = hs2.atv = hsv;
  209. hs1.alpha = hs2.alpha = a;
  210. }
  211. ]]></action>
  212. <!-- VR support -->
  213. <!-- skin styles -->
  214. <!-- skin_base - the base skin image -->
  215. <style name="skin_base" url="calc:vtourskinxmlpath.url + skin_settings.design_skin_images" />
  216. <!-- skin_glow - button glowing -->
  217. <style name="skin_glow"
  218. ondown.addevent="copy(skin_lockglow,name); skin_buttonglow(get(name));"
  219. onover.addevent="if(skin_lockglow === null, copy(skin_lockglow,name); skin_buttonglow(get(name),0.3) );"
  220. onout.addevent="if(skin_lockglow === name AND !pressed, skin_buttonglow(null);delete(skin_lockglow); );"
  221. onup.addevent="delayedcall(0, if(hovering AND enabled, skin_buttonglow(get(name),0.3); , skin_buttonglow(null);delete(skin_lockglow); ); );"
  222. />
  223. <!-- skin_thumbtext_style - style/textfield for the (optional, skin_settings.thumbs_text) thumbnails texts -->
  224. <style name="skin_thumbtext_style" type="text" align="bottom" width="100%" y="5" enabled="false" bg="false" bgborder="false" css="calc:skin_settings.design_text_css + ' text-align:center; font-size:10px;'" textshadow="get:skin_settings.design_text_shadow" />
  225. <!-- skin_hotspotstyle - style for the hotspots -->
  226. <style name="skin_hotspotstyle" url="vtourskin_hotspot.png" edge="top" distorted="true"
  227. tooltip=""
  228. linkedscene=""
  229. linkedscene_lookat=""
  230. onclick="skin_hotspotstyle_click();"
  231. depth="1000"
  232. scale="0.5"
  233. onover.addevent="tween(scale,0.55);"
  234. onout.addevent="tween(scale,0.5);"
  235. onloaded.addevent="skin_hotspotstyle_setup();"
  236. />
  237. <action name="skin_hotspotstyle_setup" scope="local">
  238. if(isvalue(caller.linkedscene) AND skin_settings.tooltips_hotspots,
  239. copy(caller.tooltip, scene[get(caller.linkedscene)].title);
  240. caller.loadstyle(skin_tooltips);
  241. );
  242. </action>
  243. <action name="skin_hotspotstyle_click" scope="local">
  244. if(isvalue(caller.linkedscene),
  245. copy(hs_linkedscene, caller.linkedscene);
  246. if(caller.linkedscene_lookat, txtsplit(caller.linkedscene_lookat, ',', hs_lookat_h, hs_lookat_v, hs_lookat_fov); );
  247. set(caller.enabled, false);
  248. skin_hidetooltips();
  249. tween(caller.depth|caller.alpha|caller.oy|caller.rx, 4000|0.0|-50|-60, 0.5, default,
  250. skin_loadscene(get(hs_linkedscene), get(skin_settings.loadscene_blend));
  251. if(hs_lookat_h !== null, skin_lookat(get(hs_lookat_h), get(hs_lookat_v), get(hs_lookat_fov)); );
  252. skin_updatescroll();
  253. );
  254. );
  255. </action>
  256. <!-- skin_tooltip - style for the thumb, hotspot and mapspot tooltips -->
  257. <style name="skin_tooltips"
  258. onover.addevent.mouse="copy(layer[skin_tooltip].html, tooltip);
  259. set(layer[skin_tooltip].visible, calc(webvr.isenabled ? false : true));
  260. tween(layer[skin_tooltip].alpha, 1.0, 0.1);
  261. asyncloop(hovering, copy(layer[skin_tooltip].x,mouse.stagex); copy(layer[skin_tooltip].y,mouse.stagey); );"
  262. onout.addevent.mouse="tween(layer[skin_tooltip].alpha, 0.0, 0.1, default, set(layer[skin_tooltip].visible,false), copy(layer[skin_tooltip].x,mouse.stagex); copy(layer[skin_tooltip].y,mouse.stagey); );"
  263. />
  264. <!-- the tooltip textfield -->
  265. <layer name="skin_tooltip" keep="true"
  266. type="text"
  267. parent="STAGE"
  268. visible="false" alpha="0" enabled="false" zorder="2"
  269. align="lefttop" edge="bottom" oy="-2" width="200"
  270. bg="false"
  271. textshadow="get:skin_settings.design_text_shadow" textshadowrange="6.0" textshadowangle="90" textshadowcolor="0x000000" textshadowalpha="1.0"
  272. css="calc:skin_settings.design_text_css + ' text-align:center; font-size:16px;'"
  273. html=""
  274. />
  275. <!-- skin layout -->
  276. <layer name="skin_layer" keep="true" type="container" align="top" width="get:skin_settings.layout_width" maxwidth="get:skin_settings.layout_maxwidth" height="100%" maskchildren="true" visible="false" bgcapture="false" zorder="1">
  277. <layer name="skin_scroll_window" type="container" align="bottom" width="100%" height="100%" x="0" y="calc:skin_settings.controlbar_offset + skin_settings.controlbar_height - skin_settings.controlbar_overlap" maskchildren="true" onloaded="skin_calc_opened_closed();" zorder="1">
  278. <layer name="skin_scroll_layer" type="container" align="bottom" width="get:skin_settings.controlbar_width" height="100%" x="0" y="200" y_offset="get:skin_settings.controlbar_overlap" accuracy="1" bgalpha="get:skin_settings.design_bgalpha" bgcolor="get:skin_settings.design_bgcolor" bgborder="get:skin_settings.design_bgborder" bgroundedge="get:skin_settings.design_bgroundedge" bgshadow="get:skin_settings.design_bgshadow">
  279. <layer name="skin_title" type="text" align="lefttop" edge="leftbottom" x="4" y="0" zorder="4" enabled="false" bg="false" css="calc:skin_settings.design_text_css + ' text-align:left; font-style:italic; font-size:12px;'" textshadow="get:skin_settings.design_text_shadow" visible="false" onautosized="skin_video_updateseekbarwidth();" />
  280. <layer name="skin_video_controls" type="container" align="lefttop" edge="leftbottom" width="100%" height="18" visible="false">
  281. <layer name="skin_video_seekbar_container" type="container" align="lefttop" width="100%" height="100%" bgcapture="true" ondown="skin_video_ondownseeking();" >
  282. <layer name="skin_video_seekbar" type="container" bgcolor="0xFFFFFF" bgalpha="0.25" align="center" width="100%" height="2">
  283. <layer name="skin_video_loadbar" type="container" bgcolor="0xFFFFFF" bgalpha="0.5" align="left" width="0" height="2" />
  284. <layer name="skin_video_seekpos" type="container" bgcolor="0xFFFFFF" bgalpha="1.0" align="left" edge="center" x="0" bgroundedge="8" width="10" height="10" />
  285. </layer>
  286. </layer>
  287. <layer name="skin_video_time" type="text" align="rightbottom" x="4" enabled="false" bg="false" css="calc:skin_settings.design_text_css + ' text-align:left; font-style:italic; font-size:12px;'" textshadow="get:skin_settings.design_text_shadow" html="0:00 / 0:00" />
  288. </layer>
  289. <layer name="skin_scroll_container" type="container" align="lefttop" width="100%" height="100%" x="0" y="0" bgroundedge="get:skin_settings.design_bgroundedge" maskchildren="true">
  290. <layer name="skin_thumbs_container" type="container" align="lefttop" width="100%" height="100%" visible="false">
  291. <layer name="skin_thumbs_scrollleft" style="skin_base|skin_glow" crop="0|64|64|64" align="lefttop" edge="left" x="5" y="50" scale="0.5" zorder="2" alpha="1.0" ondown="asyncloop(pressed, layer[skin_thumbs].scrollby(+2,0));" visible="false" />
  292. <layer name="skin_thumbs_scrollright" style="skin_base|skin_glow" crop="64|64|64|64" align="righttop" edge="right" x="5" y="50" scale="0.5" zorder="2" alpha="1.0" ondown="asyncloop(pressed, layer[skin_thumbs].scrollby(-2,0));" visible="false" />
  293. <layer name="skin_thumbs_scrollindicator" type="container" bgcolor="0xFFFFFF" bgalpha="0.25" align="lefttop" width="0" y="100" height="2" visible="false" enabled="false" />
  294. <layer name="skin_thumbs" state="closed" url.flash="%VIEWER%/plugins/scrollarea.swf" url.html5="%VIEWER%/plugins/scrollarea.js" direction="h" align="top" width="100%" height="100" zorder="1" onloaded="skin_updatescroll();" onscroll="skin_updatethumbscroll();" />
  295. </layer>
  296. <layer name="skin_map_container" type="container" align="leftop" width="100%" height="100%" bgroundedge="get:skin_settings.design_bgroundedge" maskchildren="true">
  297. <layer name="skin_map" state="closed" url="" visible="false" align="lefttop" width="100%" height="50%" x="0" y="0" zorder="1" lat="0" lng="0" zoom="10" bgalpha="0" maptype="satellite" onmapready="skin_addmapspots();">
  298. <maptypecontrol visible="true" align="righttop" x="5" y="5" buttonalign="v" scale.mobile="1.5" />
  299. <radar visible="false" headingoffset="0" />
  300. <spotstyle name="DEFAULT" url="vtourskin_mapspot.png" activeurl="vtourskin_mapspotactive.png" edge="bottom" x="-5" y="-8" scale="0.5" />
  301. <layer name="skin_map_zoom_in" style="skin_base" visible="get:skin_settings.maps_zoombuttons" crop="9|512|46|64" align="right" x="0" y="-40" zorder="2" ondown="layer[skin_map].zoomin(); skin_buttonglow(get(name));" onup="skin_buttonglow(null);" />
  302. <layer name="skin_map_zoom_out" style="skin_base" visible="get:skin_settings.maps_zoombuttons" crop="73|512|46|64" align="right" x="0" y="+40" zorder="2" ondown="layer[skin_map].zoomout(); skin_buttonglow(get(name));" onup="skin_buttonglow(null);" />
  303. </layer>
  304. </layer>
  305. </layer>
  306. </layer>
  307. </layer>
  308. <layer name="skin_splitter_bottom" type="container" align="bottom" width="100%" height="calc:skin_settings.controlbar_offset + skin_settings.controlbar_height - skin_settings.controlbar_overlap" y="0" maskchildren="true" onloaded="skin_calc_opened_closed();" zorder="2">
  309. <layer name="skin_control_bar_bg" type="container" align="bottom" width="get:skin_settings.controlbar_width" height="calc:skin_settings.controlbar_height + skin_settings.controlbar_overlap" x="0" y="get:skin_settings.controlbar_offset" bgcolor="get:skin_settings.design_bgcolor" bgalpha="get:skin_settings.design_bgalpha" bgborder="get:skin_settings.design_bgborder" bgroundedge="get:skin_settings.design_bgroundedge" bgshadow="get:skin_settings.design_bgshadow" />
  310. </layer>
  311. <layer name="skin_control_bar" type="container" align="bottom" width="get:skin_settings.controlbar_width" height="calc:skin_settings.controlbar_height" x="0" y="get:skin_settings.controlbar_offset" onloaded="skin_calc_opened_closed();" zorder="3">
  312. <layer name="skin_control_bar_buttons" type="container" align="leftbottom" width="100%" height="get:skin_settings.controlbar_height">
  313. <layer name="skin_btn_prev" style="skin_base|skin_glow" crop="0|64|64|64" align="left" x="5" y="0" scale="0.5" alpha="0.5" onclick="if(skin_settings.thumbs_loop, skin_nextscene_loop(-1), skin_nextscene(-1) );" />
  314. <layer name="skin_btn_thumbs" style="skin_base|skin_glow" crop="0|128|64|64" align="left" x="50" y="0" scale="0.5" ondown="skin_showmap(false); skin_showthumbs();" />
  315. <layer name="skin_btn_map" style="skin_base|skin_glow" crop="64|128|64|64" align="left" x="90" y="0" scale="0.5" ondown="skin_showthumbs(false); skin_showmap();" visible="false" />
  316. <layer name="skin_btn_navi" type="container" align="center" x="0" width="240" height="32">
  317. <layer name="skin_btn_left" style="skin_base|skin_glow" crop="0|192|64|64" align="center" x="-100" y="0" scale="0.5" ondown="set(hlookat_moveforce,-1);" onup="set(hlookat_moveforce,0);" />
  318. <layer name="skin_btn_right" style="skin_base|skin_glow" crop="64|192|64|64" align="center" x="-60" y="0" scale="0.5" ondown="set(hlookat_moveforce,+1);" onup="set(hlookat_moveforce,0);" />
  319. <layer name="skin_btn_up" style="skin_base|skin_glow" crop="0|256|64|64" align="center" x="-20" y="0" scale="0.5" ondown="set(vlookat_moveforce,-1);" onup="set(vlookat_moveforce,0);" />
  320. <layer name="skin_btn_down" style="skin_base|skin_glow" crop="64|256|64|64" align="center" x="+20" y="0" scale="0.5" ondown="set(vlookat_moveforce,+1);" onup="set(vlookat_moveforce,0);" />
  321. <layer name="skin_btn_in" style="skin_base|skin_glow" crop="0|320|64|64" align="center" x="+60" y="0" scale="0.5" ondown="set(fov_moveforce,-1);" onup="set(fov_moveforce,0);" />
  322. <layer name="skin_btn_out" style="skin_base|skin_glow" crop="64|320|64|64" align="center" x="+100" y="0" scale="0.5" ondown="set(fov_moveforce,+1);" onup="set(fov_moveforce,0);" />
  323. </layer>
  324. <layer name="skin_btn_gyro" style="skin_base|skin_glow" crop="0|384|64|64" align="center" x="+140" y="0" scale="0.5" onclick="switch(plugin[skin_gyro].enabled); if(plugin[skin_gyro].enabled, skin_showmap(false));" visible="false" devices="html5" />
  325. <layer name="skin_btn_vr" style="skin_base|skin_glow" crop="0|0|80|64" align="center" x="+146" y="0" scale="0.5" onclick="webvr.enterVR();" visible="false" />
  326. <layer name="skin_btn_fs" style="skin_base|skin_glow" crop="0|576|64|64" align="right" x="90" y="0" scale="0.5" onclick="switch(fullscreen);" devices="fullscreensupport" />
  327. <layer name="skin_btn_hide" style="skin_base|skin_glow" crop="0|448|64|64" align="right" x="50" y="0" scale="0.5" onclick="skin_hideskin()" />
  328. <layer name="skin_btn_show" type="container" bgcapture="true" align="bottom" width="100%" height="get:skin_settings.controlbar_height" y="calc:skin_settings.controlbar_height - skin_settings.controlbar_offset_closed" onclick="skin_showskin()" onhover="tween(alpha,1.0);" onout="tween(alpha,0.25);" ondown.touch="onhover();" onup.touch="onout();" visible="false" capture="false" alpha="0.0">
  329. <layer name="skin_btn_show_icon" style="skin_base" crop="64|448|64|64" scale="0.5" align="bottom" y="2" enabled="false" />
  330. </layer>
  331. <layer name="skin_btn_next" style="skin_base|skin_glow" crop="64|64|64|64" align="right" x="5" y="0" scale="0.5" alpha="0.5" onclick="if(skin_settings.thumbs_loop, skin_nextscene_loop(+1), skin_nextscene(+1) );" />
  332. </layer>
  333. </layer>
  334. <layer name="skin_loadingtext" type="text" align="center" x="5" y="-5" html="get:skin_settings.loadingtext" visible="false" bg="false" enabled="false" css="calc:skin_settings.design_text_css + ' text-align:center; font-style:italic; font-size:22px;'" textshadow="get:skin_settings.design_text_shadow" />
  335. <layer name="skin_buttonglow" style="skin_base" crop="64|384|64|64" align="center" x="0" y="1" scale="1.0" alpha="0.0" visible="false" enabled="false" />
  336. <layer name="skin_thumbborder" type="container" x="get:skin_settings.design_thumbborder_padding" y="get:skin_settings.design_thumbborder_padding" width="calc:skin_settings.thumbs_width - 2*skin_settings.design_thumbborder_padding" height="calc:skin_settings.thumbs_height - 2*skin_settings.design_thumbborder_padding" visible="false" enabled="false" align="lefttop" bgborder="get:skin_settings.design_thumbborder_bgborder" bgroundedge="get:skin_settings.design_thumbborder_bgroundedge" />
  337. </layer>
  338. <!-- previous/next scene buttons for the hidden skin mode -->
  339. <layer name="skin_btn_prev_fs" keep="true" type="container" align="lefttop" x="-50" width="40" height="100%" bgcapture="true" alpha="0.0" enabled="false" capture="false" zorder="2" onclick="skin_nextscene_loop(-1);" onhover="tween(alpha,1.0);" onout="tween(alpha,0.25);" ondown.touch="onhover();" onup.touch="onout();">
  340. <layer name="skin_btn_prev_fs_icon" style="skin_base" crop="0|64|64|64" align="center" scale="0.5" enabled="false" />
  341. </layer>
  342. <layer name="skin_btn_next_fs" keep="true" type="container" align="righttop" x="-50" width="40" height="100%" bgcapture="true" alpha="0.0" enabled="false" capture="false" zorder="2" onclick="skin_nextscene_loop(+1);" onhover="tween(alpha,1.0);" onout="tween(alpha,0.25);" ondown.touch="onhover();" onup.touch="onout();">
  343. <layer name="skin_btn_next_fs_icon" style="skin_base" crop="64|64|64|64" align="center" scale="0.5" enabled="false" />
  344. </layer>
  345. <!-- gyro plugin -->
  346. <plugin name="skin_gyro" keep="true" url="" html5_url="%VIEWER%/plugins/gyro2.js" softstart="1.0" desktopsupport="false" enabled="false" onavailable="skin_arrange_buttons();" devices="html5" />
  347. <!-- skin events -->
  348. <events name="skin_events" keep="true"
  349. onxmlcomplete="set(events[skin_events].onxmlcomplete, skin_showloading(true); ); skin_showloading(true); skin_startup();"
  350. onnewpano="skin_update_scene_infos(); skin_deeplinking_update_url();"
  351. onloadcomplete="skin_showloading(false);"
  352. onidle="skin_deeplinking_update_url();"
  353. onresize="skin_onresize();"
  354. onenterfullscreen.fullscreensupport="set(layer[skin_btn_fs].crop, '64|576|64|64');"
  355. onexitfullscreen.fullscreensupport="set(layer[skin_btn_fs].crop, '0|576|64|64');"
  356. onkeydown="skin_keydown_event();"
  357. />
  358. <!-- skin actions -->
  359. <action name="skin_startup" scope="local">
  360. <!-- apply skin settings on startup -->
  361. if(skin_settings.thumbs,
  362. if(skin_settings.thumbs_opened,
  363. set(layer[skin_thumbs].state, 'opened');
  364. set(layer[skin_thumbs_container].visible, true);
  365. );
  366. copy(layer[skin_thumbs].draggable, skin_settings.thumbs_dragging);
  367. if(skin_settings.thumbs_onhoverscrolling AND device.mouse,
  368. set(layer[skin_thumbs].draggable, false);
  369. set(layer[skin_thumbs].onhover_autoscrolling, true);
  370. );
  371. );
  372. if(skin_settings.gyro AND !device.desktop AND device.html5,
  373. copy(plugin[skin_gyro].url, plugin[skin_gyro].html5_url);
  374. );
  375. if(skin_settings.maps == true,
  376. set(layer[skin_btn_map].visible, true);
  377. if (skin_settings.maps_loadonfirstuse == false,
  378. skin_load_maps_plugin();
  379. );
  380. );
  381. if(skin_settings.littleplanetintro AND !global.startactions AND (device.webgl OR device.flash),
  382. skin_setup_littleplanetintro();
  383. );
  384. skin_addthumbs();
  385. skin_onresize();
  386. skin_updatescroll();
  387. set(layer[skin_layer].visible, true);
  388. </action>
  389. <action name="skin_load_maps_plugin">
  390. if (!layer[skin_map].url,
  391. if(device.flash,
  392. copy(layer[skin_map].key, skin_settings.maps_bing_api_key);
  393. set(layer[skin_map].url, '%VIEWER%/plugins/bingmaps.swf');
  394. ,
  395. if(skin_settings.maps_type == 'bing',
  396. copy(layer[skin_map].key, skin_settings.maps_bing_api_key);
  397. set(layer[skin_map].url, '%VIEWER%/plugins/bingmaps.js');
  398. ,
  399. copy(layer[skin_map].key, skin_settings.maps_google_api_key);
  400. set(layer[skin_map].url, '%VIEWER%/plugins/googlemaps.js');
  401. );
  402. );
  403. );
  404. </action>
  405. <action name="skin_addthumbs" scope="local">
  406. <!-- build a global array of visible scene thumbnails -->
  407. def(global.thumbarray, array);
  408. set(thumbcount, 0);
  409. for(set(i,0), i LT scene.count, inc(i),
  410. if(isvalue(scene[get(i)].thumburl) AND scene[get(i)].skipthumb != true,
  411. <!-- link thumbarray[i1] to scene[i2] -->
  412. set(thumbarray[get(thumbcount)], get(scene[get(i)]));
  413. set(scene[get(i)].sceneindex, get(i));
  414. set(scene[get(i)].thumbindex, get(thumbcount));
  415. inc(thumbcount);
  416. );
  417. );
  418. if(skin_settings.thumbs == false,
  419. set(layer[skin_btn_thumbs].visible,false);
  420. ,
  421. copy(thumbwidth, skin_settings.thumbs_width);
  422. copy(thumbheight, skin_settings.thumbs_height);
  423. copy(thumbpadding, skin_settings.thumbs_padding);
  424. copy(thumbcrop, skin_settings.thumbs_crop);
  425. calc(thumbxoffset, thumbwidth + thumbpadding);
  426. calc(thumbxcenter, thumbxoffset * 0.5);
  427. calc(thumbbarwidth, thumbxoffset * thumbcount + thumbpadding);
  428. calc(thumbbarheight, thumbpadding + thumbheight + thumbpadding);
  429. if(skin_settings.thumbs_scrollindicator,
  430. copy(layer[skin_thumbs_scrollindicator].y, thumbbarheight);
  431. add(thumbbarheight, layer[skin_thumbs_scrollindicator].height);
  432. );
  433. set(layer[skin_thumbs], width=get(thumbbarwidth), height=get(thumbbarheight) );
  434. calc(layer[skin_thumbs_scrollleft].y, thumbbarheight * 0.5);
  435. calc(layer[skin_thumbs_scrollright].y, thumbbarheight * 0.5);
  436. for(set(i,0), i LT thumbcount, inc(i),
  437. copy(currentscene, thumbarray[get(i)]);
  438. calc(thumbname, 'skin_thumb_' + i);
  439. addlayer(get(thumbname));
  440. set(layer[get(thumbname)],
  441. url=get(currentscene.thumburl),
  442. keep=true,
  443. parent='skin_thumbs',
  444. align='lefttop',
  445. crop=get(thumbcrop),
  446. width=get(thumbwidth),
  447. height=get(thumbheight),
  448. x=calc(thumbpadding + i*thumbxoffset),
  449. y=get(thumbpadding),
  450. linkedscene=get(currentscene.name),
  451. onclick='copy(layer[skin_thumbborder].parent, name); skin_loadscene(get(linkedscene),get(skin_settings.loadscene_blend));'
  452. );
  453. set(currentscene,
  454. thumbx=calc(thumbpadding + i*thumbxoffset + thumbxcenter),
  455. thumby=get(thumbpadding)
  456. );
  457. if(skin_settings.tooltips_thumbs,
  458. set(layer[get(thumbname)].tooltip, get(currentscene.title) );
  459. layer[get(thumbname)].loadstyle(skin_tooltips);
  460. );
  461. if(skin_settings.thumbs_text,
  462. calc(thumbtext, 'skin_thumbtext_' + i);
  463. addlayer(get(thumbtext));
  464. layer[get(thumbtext)].loadstyle(skin_thumbtext_style);
  465. set(layer[get(thumbtext)], keep=true, parent=get(thumbname), html=get(currentscene.title) );
  466. );
  467. );
  468. if(thumbcount == 1,
  469. set(layer[skin_thumbs].align, 'lefttop');
  470. );
  471. );
  472. </action>
  473. <!-- called from bing- or google-maps plugin onmapready event -->
  474. <action name="skin_addmapspots" scope="local">
  475. for(set(i,0), i LT scene.count, inc(i),
  476. if(scene[get(i)].lat,
  477. calc(spotname, 'spot' + i);
  478. calc(spotclickevent, 'skin_hidetooltips(); activatespot(' + spotname + '); skin_loadscene(' + scene[get(i)].name + ',get(skin_settings.loadscene_blend)); skin_updatescroll(); delayedcall(0.5,skin_showmap(false));' );
  479. copy(scene[get(i)].mapspotname, spotname);
  480. caller.addspot(get(spotname), get(scene[get(i)].lat), get(scene[get(i)].lng), get(scene[get(i)].heading), false, get(spotclickevent), null);
  481. if(skin_settings.tooltips_mapspots,
  482. set(layer[skin_map].spot[get(spotname)].tooltip, get(scene[get(i)].title) );
  483. txtadd(layer[skin_map].spot[get(spotname)].onover, 'set(hovering,true);', get(style[skin_tooltips].onover) );
  484. txtadd(layer[skin_map].spot[get(spotname)].onout, 'set(hovering,false);', get(style[skin_tooltips].onout) );
  485. );
  486. );
  487. );
  488. caller.activatespot( calc(xml.scene != null ? scene[get(xml.scene)].mapspotname : 'spot0') );
  489. caller.zoomToSpotsExtent();
  490. </action>
  491. <action name="skin_setup_littleplanetintro" scope="local">
  492. skin_hideskin(instant);
  493. set(global.lpinfo, scene=get(xml.scene), hlookat=get(view.hlookat), vlookat=get(view.vlookat), fov=get(view.fov), fovmax=get(view.fovmax), limitview=get(view.limitview) );
  494. set(view, fovmax=170, limitview=lookto, vlookatmin=90, vlookatmax=90);
  495. lookat(calc(global.lpinfo.hlookat - 180), 90, 150, 1, 0, 0);
  496. set(events[lp_events].onloadcomplete,
  497. delayedcall(0.5,
  498. if(lpinfo.scene === xml.scene,
  499. set(control.usercontrol, off);
  500. set(view, limitview=get(lpinfo.limitview), vlookatmin=null, view.vlookatmax=null);
  501. tween(view.hlookat|view.vlookat|view.fov|view.distortion, calc('' + lpinfo.hlookat + '|' + lpinfo.vlookat + '|' + lpinfo.fov + '|' + 0.0), 3.0, easeOutQuad);
  502. delayedcall(3.0,
  503. set(control.usercontrol, all);
  504. tween(view.fovmax, get(lpinfo.fovmax));
  505. skin_deeplinking_update_url();
  506. delete(global.lpinfo);
  507. skin_showskin();
  508. if(skin_settings.thumbs AND skin_settings.thumbs_opened, skin_showthumbs() );
  509. );
  510. ,
  511. delete(global.lpinfo);
  512. );
  513. );
  514. );
  515. </action>
  516. <action name="skin_lookat" scope="local" args="h, v, fov">
  517. if(webvr.isenabled,
  518. <!-- adjust the VR prev/next hotspots for the view change -->
  519. calc(hlookat_offset, h - view.hlookat);
  520. add(hotspot[skin_webvr_prev_scene].ath, hlookat_offset);
  521. add(hotspot[skin_webvr_next_scene].ath, hlookat_offset);
  522. );
  523. if(plugin[skin_gyro].isavailable AND plugin[skin_gyro].enabled,
  524. <!-- reset the gyro tracking -->
  525. plugin[skin_gyro].resetsensor(get(h));
  526. );
  527. <!-- change the view -->
  528. lookat(get(h), get(v), get(fov));
  529. </action>
  530. <action name="skin_onresize" scope="local">
  531. mul(mh, area.pixelheight, -1);
  532. if(layer[skin_thumbs].state == 'opened', add(mh,layer[skin_thumbs].height); );
  533. if(layer[skin_map].state == 'opened', sub(hh,area.pixelheight,skin_settings.controlbar_offset); sub(hh,layer[skin_control_bar].height); sub(hh,32); add(mh,hh); add(mh,skin_settings.controlbar_overlap); sub(mh, layer[skin_scroll_layer].y_offset); copy(layer[skin_map].height, hh); );
  534. add(mh, layer[skin_scroll_layer].y_offset);
  535. set(layer[skin_scroll_layer].y, get(mh));
  536. if(display.safearea_inset, calc(layer[skin_btn_show].y, skin_settings.controlbar_height - skin_settings.controlbar_offset_closed - (display.safearea_inset.b LT 0 ? display.safearea_inset.b : 0)); );
  537. skin_video_updateseekbarwidth();
  538. skin_arrange_buttons();
  539. </action>
  540. <!-- determine the visibility of the buttons and calculate their positions -->
  541. <action name="skin_arrange_buttons" scope="local">
  542. calc(show_selbuttons, scene.count GT 1);
  543. calc(show_thumbutton, skin_settings.thumbs == true);
  544. calc(show_mapbutton, skin_settings.maps == true);
  545. calc(show_gyrobutton, plugin[skin_gyro].isavailable == true AND (view.vlookatrange == 180 OR global.lpinfo.scene === xml.scene));
  546. calc(show_vrbutton, webvr.isavailable == true);
  547. calc(show_fsbutton, device.fullscreensupport == true);
  548. set(lpos,6);
  549. set(cpos,0);
  550. if(show_gyrobutton, dec(cpos,20));
  551. if(show_vrbutton OR plugin[webvr].mobilevr_fake_support == true, dec(cpos,24));
  552. set(rpos,6);
  553. calc(show_dirbuttons, !device.mobile AND ((area.pixelwidth + 2*cpos) GT 520) );
  554. copy(layer[skin_btn_navi].visible, show_dirbuttons);
  555. copy(layer[skin_btn_prev].visible, show_selbuttons);
  556. copy(layer[skin_btn_next].visible, show_selbuttons);
  557. if(show_selbuttons, inc(lpos,44); inc(rpos,44); );
  558. copy(layer[skin_btn_thumbs].visible, show_thumbutton);
  559. copy(layer[skin_btn_thumbs].x, lpos);
  560. if(show_thumbutton, inc(lpos,40));
  561. copy(layer[skin_btn_map].visible, show_mapbutton);
  562. copy(layer[skin_btn_map].x, lpos);
  563. if(show_mapbutton, inc(lpos,40));
  564. if(show_dirbuttons,
  565. copy(layer[skin_btn_navi].x, cpos);
  566. inc(cpos,140);
  567. set(layer[skin_btn_gyro].align, center);
  568. copy(layer[skin_btn_gyro].visible, show_gyrobutton);
  569. copy(layer[skin_btn_gyro].x, cpos);
  570. if(show_gyrobutton, inc(cpos,48));
  571. set(layer[skin_btn_vr].align, center);
  572. copy(layer[skin_btn_vr].visible, show_vrbutton);
  573. copy(layer[skin_btn_vr].x, cpos);
  574. if(show_vrbutton, inc(cpos,80));
  575. ,
  576. set(layer[skin_btn_gyro].align, left);
  577. copy(layer[skin_btn_gyro].visible, show_gyrobutton);
  578. copy(layer[skin_btn_gyro].x, lpos);
  579. if(show_gyrobutton, inc(lpos,40));
  580. set(layer[skin_btn_vr].align, left);
  581. copy(layer[skin_btn_vr].visible, show_vrbutton);
  582. copy(layer[skin_btn_vr].x, lpos);
  583. if(show_vrbutton, inc(lpos,80));
  584. );
  585. copy(layer[skin_btn_hide].x, rpos);
  586. inc(rpos,40);
  587. copy(layer[skin_btn_fs].visible, show_fsbutton);
  588. copy(layer[skin_btn_fs].x, rpos);
  589. if(show_fsbutton, inc(rpos,40));
  590. </action>
  591. <action name="skin_updatescroll" scope="local">
  592. if(layer[skin_thumbs].loaded,
  593. set(cursceneindex, 0);
  594. if(xml.scene, copy(cursceneindex, scene[get(xml.scene)].index));
  595. layer[skin_thumbs].setcenter(get(scene[get(cursceneindex)].thumbx), get(scene[get(cursceneindex)].thumby));
  596. );
  597. </action>
  598. <action name="skin_updatethumbscroll" scope="local">
  599. copy(padding,skin_settings.thumbs_padding);
  600. if(skin_settings.thumbs_scrollbuttons,
  601. if(caller.loverflow GT 0, set(layer[skin_thumbs_scrollleft].visible,true), set(layer[skin_thumbs_scrollleft].visible,false) );
  602. if(caller.roverflow GT 0, set(layer[skin_thumbs_scrollright].visible,true), set(layer[skin_thumbs_scrollright].visible,false) );
  603. );
  604. if(skin_settings.thumbs_scrollindicator,
  605. if(caller.woverflow GT 0,
  606. set(layer[skin_thumbs_scrollindicator].visible, true);
  607. sub(iw,caller.pixelwidth,caller.woverflow);
  608. div(pw,iw,caller.pixelwidth);
  609. div(px,caller.loverflow,caller.woverflow);
  610. mul(pw,iw);
  611. copy(layer[skin_thumbs_scrollindicator].width, pw);
  612. sub(iw,pw);
  613. sub(iw,padding);
  614. sub(iw,padding);
  615. mul(px,iw);
  616. add(px,padding);
  617. copy(layer[skin_thumbs_scrollindicator].x, px);
  618. ,
  619. set(layer[skin_thumbs_scrollindicator].visible, false);
  620. );
  621. );
  622. </action>
  623. <action name="skin_update_scene_infos" scope="local">
  624. if(xml.scene !== null AND scene[get(xml.scene)].index GE 0,
  625. if(skin_settings.title,
  626. if(global.title, calc(layer[skin_title].html, global.title + ' - ' + scene[get(xml.scene)].title); , copy(layer[skin_title].html, scene[get(xml.scene)].title ); );
  627. delayedcall(0.1, set(layer[skin_title].visible,true) );
  628. );
  629. if(skin_settings.thumbs_loop == false,
  630. if(scene[get(xml.scene)].index GT 0,
  631. set(layer[skin_btn_prev], enabled=true, alpha=1.0);
  632. ,
  633. set(layer[skin_btn_prev], enabled=false, alpha=0.3);
  634. );
  635. sub(lastsceneindex, scene.count, 1);
  636. if(scene[get(xml.scene)].index LT lastsceneindex,
  637. set(layer[skin_btn_next], enabled=true, alpha=1.0);
  638. ,
  639. set(layer[skin_btn_next], enabled=false, alpha=0.3);
  640. );
  641. ,
  642. if(scene.count GT 1,
  643. set(layer[skin_btn_prev], enabled=true, alpha=1.0);
  644. set(layer[skin_btn_next], enabled=true, alpha=1.0);
  645. ,
  646. set(layer[skin_btn_prev], enabled=false, alpha=0.3);
  647. set(layer[skin_btn_next], enabled=false, alpha=0.3);
  648. );
  649. );
  650. if(scene.count GT 1,
  651. set(layer[skin_btn_prev_fs].visible, true);
  652. set(layer[skin_btn_next_fs].visible, true);
  653. ,
  654. set(layer[skin_btn_prev_fs].visible, false);
  655. set(layer[skin_btn_next_fs].visible, false);
  656. );
  657. calc(parentname, 'skin_thumb_' + scene[get(xml.scene)].thumbindex);
  658. if(scene[get(xml.scene)].thumburl AND scene[get(xml.scene)].skipthumb != true AND layer[get(parentname)],
  659. set(layer[skin_thumbborder], parent=get(parentname), visible=true);
  660. ,
  661. set(layer[skin_thumbborder].visible, false);
  662. );
  663. if(scene[get(xml.scene)].mapspotname,
  664. layer[skin_map].activatespot(get(scene[get(xml.scene)].mapspotname));
  665. layer[skin_map].pantospot(get(scene[get(xml.scene)].mapspotname));
  666. );
  667. if(plugin[skin_gyro].isavailable == true AND (view.vlookatrange == 180 OR global.lpinfo.scene === xml.scene),
  668. set(layer[skin_btn_gyro].visible, true);
  669. ,
  670. set(layer[skin_btn_gyro].visible, false)
  671. );
  672. if(scene[get(xml.scene)].isvideopano AND plugin[video] !== null,
  673. skin_video_addcontrols();
  674. ,
  675. skin_video_removecontrols();
  676. );
  677. );
  678. </action>
  679. <action name="skin_gotoscene" scope="local" args="newscene">
  680. if(scene[get(newscene)],
  681. copy(cursceneindex, scene[get(xml.scene)].index);
  682. copy(newsceneindex, scene[get(newscene)].index);
  683. skin_loadscene(get(newsceneindex), calc(newsceneindex LT cursceneindex ? skin_settings.loadscene_blend_prev : (newsceneindex GT cursceneindex ? skin_settings.loadscene_blend_next : skin_settings.loadscene_blend)) );
  684. );
  685. </action>
  686. <action name="skin_nextscene" scope="local" args="indexadd">
  687. set(newscenename, null);
  688. if(isset(scene[get(xml.scene)].thumbindex),
  689. add(newsceneindex, scene[get(xml.scene)].thumbindex, indexadd);
  690. if(newsceneindex GE 0 AND newsceneindex LT thumbarray.length,
  691. set(newscenename, get(thumbarray[get(newsceneindex)].name));
  692. );
  693. ,
  694. add(newsceneindex, scene[get(xml.scene)].index, indexadd);
  695. if(newsceneindex GE 0 AND newsceneindex LT scene.count,
  696. set(newscenename, get(scene[get(newsceneindex)].name));
  697. );
  698. );
  699. if(newscenename != null,
  700. skin_loadscene(get(newscenename), calc(indexadd LT 0 ? skin_settings.loadscene_blend_prev : skin_settings.loadscene_blend_next));
  701. );
  702. </action>
  703. <action name="skin_nextscene_loop" scope="local" args="indexadd">
  704. set(newscenename, null);
  705. if(isset(scene[get(xml.scene)].thumbindex),
  706. sub(lastsceneindex, thumbarray.length, 1);
  707. add(newsceneindex, scene[get(xml.scene)].thumbindex, indexadd);
  708. if(newsceneindex LT 0, copy(newsceneindex,lastsceneindex));
  709. if(newsceneindex GT lastsceneindex, set(newsceneindex,0));
  710. set(newscenename, get(thumbarray[get(newsceneindex)].name));
  711. ,
  712. add(newsceneindex, scene[get(xml.scene)].index, indexadd);
  713. sub(lastsceneindex, scene.count, 1);
  714. if(newsceneindex LT 0, copy(newsceneindex,lastsceneindex));
  715. if(newsceneindex GT lastsceneindex, set(newsceneindex,0));
  716. set(newscenename, get(scene[get(newsceneindex)].name));
  717. );
  718. if(newscenename != null,
  719. skin_loadscene(get(newscenename), calc(indexadd LT 0 ? skin_settings.loadscene_blend_prev : skin_settings.loadscene_blend_next));
  720. );
  721. </action>
  722. <action name="skin_loadscene" scope="local" args="newscenenameorindex, blendmode">
  723. if(webvr.isenabled AND scene.count GT 1,
  724. set(hotspot[skin_webvr_prev_scene].visible, false);
  725. set(hotspot[skin_webvr_next_scene].visible, false);
  726. );
  727. calc(parentname, 'skin_thumb_' + scene[get(newscenenameorindex)].thumbindex);
  728. if(scene[get(newscenenameorindex)].thumburl AND scene[get(newscenenameorindex)].skipthumb != true AND layer[get(parentname)],
  729. set(layer[skin_thumbborder], parent=get(parentname), visible=true);
  730. ,
  731. set(layer[skin_thumbborder].visible, false);
  732. );
  733. layer[skin_thumbs].scrolltocenter(get(scene[get(newscenenameorindex)].thumbx), get(scene[get(newscenenameorindex)].thumby));
  734. loadscene(get(scene[get(newscenenameorindex)].name), null, get(skin_settings.loadscene_flags), get(blendmode));
  735. </action>
  736. <action name="skin_showloading" scope="private:SKINLOADINGCHECK" args="state">
  737. if(state == true AND global.display.stereo == false,
  738. <!-- start loading -->
  739. set(loadingstate, 1);
  740. delayedcall(2.0,
  741. if(loadingstate == 1,
  742. <!-- after 2.0 seconds still not loaded? => show the loading text -->
  743. set(global.layer[skin_loadingtext].visible, true);
  744. );
  745. );
  746. ,
  747. <!-- stop loading -->
  748. set(loadingstate, 2);
  749. set(global.layer[skin_loadingtext].visible, false);
  750. );
  751. </action>
  752. <action name="skin_hidetooltips">
  753. set(layer[skin_tooltip], alpha=0.0, visible=false);
  754. </action>
  755. <action name="skin_buttonglow" scope="local" args="layertoglow, strength">
  756. if(layertoglow != null,
  757. if(strength == null, set(strength,0.7));
  758. set(layer[skin_buttonglow], parent=get(layertoglow), visible=true);
  759. tween(layer[skin_buttonglow].alpha, get(strength), 0.07);
  760. ,
  761. tween(layer[skin_buttonglow].alpha, 0.0, 0.1, default, set(layer[skin_buttonglow], parent=null, visible=false); );
  762. );
  763. </action>
  764. <action name="skin_calc_opened_closed">
  765. if(layer[get(name)].y_closed === null,
  766. set(layer[get(name)].y_opened, get(layer[get(name)].y));
  767. set(layer[get(name)].y_closed, calc(layer[get(name)].y - skin_settings.controlbar_offset - skin_settings.controlbar_height + skin_settings.controlbar_offset_closed));
  768. );
  769. </action>
  770. <action name="skin_hideskin" scope="local" args="hidetimemode">
  771. calc(hidetime, hidetimemode == 'instant' ? 0.0 : 0.5);
  772. callwith(layer[skin_scroll_window], skin_calc_opened_closed() );
  773. callwith(layer[skin_splitter_bottom], skin_calc_opened_closed() );
  774. callwith(layer[skin_control_bar], skin_calc_opened_closed() );
  775. if(layer[skin_map].state != 'closed', skin_showmap(false); if(hidetime GT 0, wait(0.40)); );
  776. if(layer[skin_thumbs].state != 'closed', skin_showthumbs(false); if(hidetime GT 0, wait(0.25)); );
  777. tween(layer[skin_scroll_window].y, get(layer[skin_scroll_window ].y_closed), get(hidetime));
  778. tween(layer[skin_splitter_bottom].y, get(layer[skin_splitter_bottom].y_closed), get(hidetime));
  779. tween(layer[skin_control_bar].y, get(layer[skin_control_bar ].y_closed), get(hidetime));
  780. set(layer[skin_btn_prev_fs].enabled, true);
  781. set(layer[skin_btn_next_fs].enabled, true);
  782. tween(layer[skin_btn_prev_fs].x|layer[skin_btn_prev_fs].alpha, 0|0.25, get(hidetime));
  783. tween(layer[skin_btn_next_fs].x|layer[skin_btn_next_fs].alpha, 0|0.25, get(hidetime));
  784. if(layer[skin_logo], tween(layer[skin_logo].alpha, 0.0, 0.5, default, set(layer[skin_logo].visible,false)); );
  785. stopdelayedcall(skin_btn_show_alpha);
  786. set(layer[skin_btn_show].visible, true);
  787. delayedcall(skin_btn_show_alpha, get(hidetime), tween(layer[skin_btn_show].alpha, 0.25, 0.25); );
  788. </action>
  789. <action name="skin_showskin">
  790. tween(layer[skin_scroll_window ].y, get(layer[skin_scroll_window ].y_opened));
  791. tween(layer[skin_splitter_bottom].y, get(layer[skin_splitter_bottom].y_opened));
  792. tween(layer[skin_control_bar ].y, get(layer[skin_control_bar ].y_opened));
  793. set(layer[skin_btn_prev_fs].enabled, false);
  794. set(layer[skin_btn_next_fs].enabled, false);
  795. tween(layer[skin_btn_prev_fs].x|layer[skin_btn_prev_fs].alpha, -50|0.0);
  796. tween(layer[skin_btn_next_fs].x|layer[skin_btn_next_fs].alpha, -50|0.0);
  797. if(layer[skin_logo], set(layer[skin_logo].visible,true); tween(layer[skin_logo].alpha, 1.0); );
  798. stopdelayedcall(skin_btn_show_alpha);
  799. set(layer[skin_btn_show].visible, false);
  800. delayedcall(skin_btn_show_alpha, 0.25, tween(layer[skin_btn_show].alpha, 0.0, 0.0); );
  801. </action>
  802. <action name="skin_showthumbs" scope="local" args="show">
  803. if(show == null, if(layer[skin_thumbs].state == 'closed', set(show,true), set(show,false)); );
  804. if(show,
  805. set(layer[skin_thumbs].state, 'opened');
  806. tween(layer[skin_thumbs].alpha, 1.0, 0.25);
  807. tween(layer[skin_scroll_layer].y, calc(-area.pixelheight + layer[skin_thumbs].height + layer[skin_scroll_layer].y_offset), 0.5, easeOutQuint);
  808. set(layer[skin_thumbs_container].visible, true);
  809. tween(layer[skin_thumbs_container].alpha, 1.0, 0.25);
  810. tween(layer[skin_map].alpha, 0.0, 0.25, default, set(layer[skin_map].visible,false));
  811. ,
  812. set(layer[skin_thumbs].state, 'closed');
  813. tween(layer[skin_thumbs].alpha, 0.0, 0.25, easeOutQuint);
  814. tween(layer[skin_scroll_layer].y, calc(-area.pixelheight + layer[skin_scroll_layer].y_offset), 0.5, easeOutQuint, set(layer[skin_thumbs_container].visible, false););
  815. );
  816. </action>
  817. <action name="skin_showmap" scope="local" args="show">
  818. if(show == null, if(layer[skin_map].state == 'closed', set(show,true), set(show,false)); );
  819. if(show,
  820. skin_load_maps_plugin();
  821. tween(layer[skin_thumbs_container].alpha, 0.0, 0.25, default, set(layer[skin_thumbs_container].visible,false));
  822. set(layer[skin_map].visible, true);
  823. tween(layer[skin_map].alpha, 1.0, 0.25);
  824. set(layer[skin_map].state, 'opened');
  825. calc(hh, area.pixelheight - skin_settings.controlbar_offset - layer[skin_control_bar].height - 32);
  826. calc(layer[skin_map].height, hh - skin_settings.controlbar_overlap);
  827. tween(layer[skin_scroll_layer].y, calc(hh - area.pixelheight), 0.5, easeOutQuint);
  828. ,
  829. if(layer[skin_map].state != 'closed',
  830. set(layer[skin_map].state, 'closed');
  831. tween(layer[skin_map].alpha, 0.0, 0.5, easeOutQuint);
  832. tween(layer[skin_scroll_layer].y, calc(-area.pixelheight + layer[skin_scroll_layer].y_offset), 0.5, easeOutQuint, set(layer[skin_map].visible,false) );
  833. );
  834. );
  835. </action>
  836. <action name="skin_keydown_event">
  837. if(keycode == 33, skin_nextscene_loop(-1) ); <!-- Page Up - previous scene -->
  838. if(keycode == 34, skin_nextscene_loop(+1) ); <!-- Page Dowm - next scene -->
  839. if(keycode == 35, skin_gotoscene(calc(scene.count-1)) ); <!-- End - last scene -->
  840. if(keycode == 36, skin_gotoscene(0) ); <!-- Home/Pos1 - first scene -->
  841. </action>
  842. <action name="skin_deeplinking_update_url" scope="local" args="delay">
  843. if(skin_settings.deeplinking AND (!webvr OR webvr.isenabled === false) AND global.lpinfo === null,
  844. delayedcall(skin_deeplinking_update, calc(delay == null ? 0.1 : delay), skin_deeplinking_update_url_process() );
  845. );
  846. </action>
  847. <action name="skin_deeplinking_update_url_process" scope="local">
  848. copy(adr, browser.location);
  849. indexoftxt(qi, get(adr), '?');
  850. if(qi GT 0, subtxt(adr, adr, 0, get(qi)));
  851. copy(si, scene[get(xml.scene)].index);
  852. copy(h, view.hlookat);
  853. copy(v, view.vlookat);
  854. copy(f, view.fov);
  855. copy(d, view.distortion);
  856. copy(a, view.architectural);
  857. clamp(d, 0.0, 1.0);
  858. clamp(a, 0.0, 1.0);
  859. set(pp, calc(f LT 10 ? 6 : 2));
  860. roundval(h, get(pp));
  861. roundval(v, get(pp));
  862. roundval(f, get(pp));
  863. roundval(d, 2);
  864. roundval(a, 1);
  865. set(adr, calc(adr + '?startscene=' + si + '&amp;startactions=lookat('+h+','+v+','+f+','+d+','+a+');'));
  866. js( history.replaceState(null, document.title, get(adr)); );
  867. </action>
  868. <!-- reload the scene when there is a special image for VR -->
  869. <action name="skin_reloadscene_webvr" scope="local">
  870. delayedcall(0.1,
  871. if(scene[get(xml.scene)].havevrimage,
  872. copy(skin_settings.keeplookingdirection_backup, skin_settings.webvr_keeplookingdirection);
  873. set(skin_settings.webvr_keeplookingdirection, true);
  874. loadscene(get(xml.scene), null, MERGE|KEEPVIEW|KEEPMOVING|KEEPPLUGINS|KEEPHOTSPOTS, BLEND(0.5));
  875. copy(skin_settings.webvr_keeplookingdirection, skin_settings.keeplookingdirection_backup);
  876. delete(skin_settings.keeplookingdirection_backup);
  877. );
  878. );
  879. </action>
  880. <!-- videopano support - https://krpano.com/plugins/videoplayer/ -->
  881. <action name="skin_video_addcontrols">
  882. set(events[skin_events].onclick, skin_video_clickevent() );
  883. set(plugin[video].onvideoready, skin_video_updatestate() );
  884. set(plugin[video].onvideoplay, skin_video_updatestate() );
  885. set(plugin[video].onvideopaused, skin_video_updatestate() );
  886. set(plugin[video].onvideocomplete, skin_video_updatestate() );
  887. if(plugin[video].ispaused AND plugin[video].pausedonstart,
  888. set(layer[skin_video_playpause].state, 'visible');
  889. set(layer[skin_video_playpause].enabled, true);
  890. tween(layer[skin_video_playpause].alpha, 1.0);
  891. );
  892. delayedcall(skin_video_delayedvisible, 0.25, set(layer[skin_video_controls].visible, true) );
  893. skin_video_updateseekbarwidth();
  894. set(layer[skin_video_seekpos].x,0);
  895. set(layer[skin_video_loadbar].width,0);
  896. setinterval(skin_video_seek_updates, 0.5, skin_video_updatetime() );
  897. </action>
  898. <action name="skin_video_removecontrols">
  899. stopdelayedcall(skin_video_delayedvisible);
  900. set(events[skin_events].onclick, null);
  901. set(layer[skin_video_playpause].alpha, 0.0);
  902. set(layer[skin_video_controls].visible, false);
  903. clearinterval(skin_video_seek_updates);
  904. </action>
  905. <action name="skin_video_updatetime" scope="local" args="seekpos">
  906. copy(t1, plugin[video].time);
  907. copy(t2, plugin[video].totaltime);
  908. if(seekpos != null, calc(t1, seekpos * t2); );
  909. div(t1_min, t1, 60);
  910. mod(t1_sec, t1, 60);
  911. Math.floor(t1_min);
  912. Math.floor(t1_sec);
  913. div(t2_min, t2, 60);
  914. mod(t2_sec, t2, 60);
  915. Math.floor(t2_min);
  916. Math.floor(t2_sec);
  917. calc(layer[skin_video_time].html, t1_min + ':' + (t1_sec LT 10 ? '0' : '') + t1_sec + ' / ' + t2_min + ':' + (t2_sec LT 10 ? '0' : '') + t2_sec);
  918. calc(layer[skin_video_seekpos].x, (t1 / t2 * 100) + '%');
  919. calc(layer[skin_video_loadbar].width, (plugin[video].loadedbytes / plugin[video].totalbytes * 100) + '%');
  920. </action>
  921. <action name="skin_video_updateseekbarwidth">
  922. if(skin_settings.title,
  923. calc(layer[skin_video_seekbar_container].width, 0 - (32 + layer[skin_title].pixelwidth + layer[skin_video_time].pixelwidth));
  924. calc(layer[skin_video_seekbar_container].x, layer[skin_title].pixelwidth + 16);
  925. ,
  926. calc(layer[skin_video_seekbar_container].width, 0 - (24 + layer[skin_video_time].pixelwidth));
  927. set(layer[skin_video_seekbar_container].x, 8);
  928. );
  929. </action>
  930. <action name="skin_video_ondownseeking" scope="local">
  931. asyncloop(caller.pressed,
  932. screentolayer(skin_video_seekbar, mouse.stagex,mouse.stagey, lx,ly);
  933. calc(seekpos, lx / layer[skin_video_seekbar].pixelwidth);
  934. clamp(seekpos, 0.0, 1.0);
  935. skin_video_updatetime(get(seekpos));
  936. ,
  937. plugin[video].seek(calc((seekpos * 100) + '%'));
  938. );
  939. </action>
  940. <layer name="skin_video_playpause" keep="true"
  941. style="skin_base|skin_glow" crop="0|640|64|64" scale="0.75"
  942. align="center" alpha="0.0" autoalpha="true"
  943. state="hidden"
  944. onclick="skin_video_playpause_click();"
  945. />
  946. <action name="skin_video_updatestate">
  947. calc(layer[skin_video_playpause].crop, plugin[video].ispaused ? '0|640|64|64' : '64|640|64|64');
  948. if(plugin[video].iscomplete,
  949. set(layer[skin_video_playpause].state, 'visible');
  950. tween(layer[skin_video_playpause].alpha, 1.0);
  951. );
  952. </action>
  953. <action name="skin_video_playpause_click">
  954. if(plugin[video].ispaused,
  955. plugin[video].play();
  956. set(layer[skin_video_playpause].state, 'hidden');
  957. tween(layer[skin_video_playpause].alpha, 0.0);
  958. ,
  959. plugin[video].pause();
  960. set(layer[skin_video_playpause].state, 'visible');
  961. tween(layer[skin_video_playpause].alpha, 1.0);
  962. delayedcall(autohide_pp, 2.0, set(layer[skin_video_playpause].state,'hidden'); tween(layer[skin_video_playpause].alpha, 0.0); );
  963. );
  964. </action>
  965. <action name="skin_video_clickevent">
  966. stopdelayedcall(autohide_pp);
  967. switch(layer[skin_video_playpause].state, 'visible', 'hidden');
  968. if(layer[skin_video_playpause].state == 'hidden',
  969. tween(layer[skin_video_playpause].alpha, 0.0);
  970. ,
  971. tween(layer[skin_video_playpause].alpha, 1.0);
  972. delayedcall(autohide_pp, 2.0, set(layer[skin_video_playpause].state,'hidden'); tween(layer[skin_video_playpause].alpha, 0.0); );
  973. );
  974. </action>
  975. <!-- autotour/autoplay support -->
  976. <autorotate enabled="calc:skin_settings.autotour == true"
  977. waittime="5.0"
  978. accel="0.7"
  979. speed="4.0"
  980. tofov="80"
  981. oneroundrange="360"
  982. />
  983. <events name="skin_autotour" keep="true"
  984. onautorotatestart="if(skin_settings.autotour, skin_autotour_start(); );"
  985. onautorotatestop="if(skin_settings.autotour, skin_autotour_stop(); );"
  986. onautorotateoneround="if(skin_settings.autotour, skin_nextscene_loop(+1); );"
  987. />
  988. <action name="skin_autotour_start" scope="PRIVATE:skin_autotour">
  989. copy(loadscene_flags_backup, global.skin_settings.loadscene_flags);
  990. set(global.skin_settings.loadscene_flags, MERGE|KEEPVIEW|KEEPMOVING|PRELOAD);
  991. copy(loadscene_blend_next_backup, global.skin_settings.loadscene_blend_next);
  992. set(global.skin_settings.loadscene_blend_next, SLIDEBLEND(2.0, 0, 0.75, linear) );
  993. </action>
  994. <action name="skin_autotour_stop" scope="PRIVATE:skin_autotour">
  995. copy(global.skin_settings.loadscene_flags, loadscene_flags_backup);
  996. copy(global.skin_settings.loadscene_blend_next, loadscene_blend_next_backup);
  997. </action>
  998. <!-- context menu - https://krpano.com/docu/xml/#contextmenu -->
  999. <contextmenu>
  1000. <item name="kr" caption="KRPANO" />
  1001. <item name="fs" caption="FULLSCREEN" />
  1002. <item name="cc" caption="Change Controlmode" onclick="skin_changecontrolmode();" separator="above" />
  1003. <item name="nv" caption="Normal View" onclick="skin_view_normal();" showif="view.vlookatrange == 180" separator="above" />
  1004. <item name="fv" caption="Fisheye View" onclick="skin_view_fisheye();" showif="view.vlookatrange == 180" devices="flash|webgl" />
  1005. <item name="sv" caption="Stereographic View" onclick="skin_view_stereographic();" showif="view.vlookatrange == 180" devices="flash|webgl" />
  1006. <item name="av" caption="Architectural View" onclick="skin_view_architectural();" showif="view.vlookatrange == 180" />
  1007. <item name="pv" caption="Pannini View" onclick="skin_view_pannini();" showif="view.vlookatrange == 180" devices="flash|webgl" />
  1008. <item name="lp" caption="Little Planet View" onclick="skin_view_littleplanet();" showif="view.vlookatrange == 180" devices="flash|webgl" />
  1009. <item name="sa" caption="Start Autotour" onclick="autorotate.start();" separator="both" showif="autorotate.isrotating == false" visible="calc:skin_settings.autotour == true" />
  1010. <item name="ta" caption="Stop Autotour" onclick="autorotate.stop();" separator="both" showif="autorotate.isrotating == true" visible="calc:skin_settings.autotour == true" />
  1011. </contextmenu>
  1012. <action name="skin_changecontrolmode">
  1013. if(device.html5,
  1014. switch(control.mode, moveto, drag, follow);
  1015. skin_changecontrolmode_updatecaption();
  1016. ,
  1017. switch(control.mode, moveto, drag);
  1018. );
  1019. </action>
  1020. <action name="skin_changecontrolmode_updatecaption" autorun="onstart" devices="html5">
  1021. txtadd(contextmenu.item[cc].caption,
  1022. "Controlmode: ",
  1023. "[span style=[sq]", calc(control.mode == 'drag' ? "text-decoration:underline" :""), "[sq]]",
  1024. "Drag",
  1025. "[/span]",
  1026. " | ",
  1027. "[span style=[sq]", calc(control.mode == 'follow' ? "text-decoration:underline" :""), "[sq]]",
  1028. "Follow",
  1029. "[/span]",
  1030. " | ",
  1031. "[span style=[sq]", calc(control.mode == 'moveto' ? "text-decoration:underline" :""), "[sq]]",
  1032. "MoveTo",
  1033. "[/span]",
  1034. );
  1035. </action>
  1036. <action name="skin_view_look_straight">
  1037. if(view.vlookat LT -80 OR view.vlookat GT +80,
  1038. tween(view.vlookat, 0.0, 1.0, easeInOutSine);
  1039. tween(view.fov, 100, distance(150,0.8));
  1040. );
  1041. skin_deeplinking_update_url(1.0);
  1042. </action>
  1043. <action name="skin_view_normal">
  1044. skin_view_look_straight();
  1045. tween(view.architectural, 0.0, distance(1.0,0.5));
  1046. tween(view.pannini, 0.0, distance(1.0,0.5));
  1047. tween(view.distortion, 0.0, distance(1.0,0.5));
  1048. </action>
  1049. <action name="skin_view_fisheye">
  1050. skin_view_look_straight();
  1051. tween(view.architectural, 0.0, distance(1.0,0.5));
  1052. tween(view.pannini, 0.0, distance(1.0,0.5));
  1053. tween(view.distortion, 0.35, distance(1.0,0.5));
  1054. </action>
  1055. <action name="skin_view_architectural">
  1056. skin_view_look_straight();
  1057. tween(view.architectural, 1.0, distance(1.0,0.5));
  1058. tween(view.pannini, 0.0, distance(1.0,0.5));
  1059. tween(view.distortion, 0.0, distance(1.0,0.5));
  1060. </action>
  1061. <action name="skin_view_stereographic">
  1062. skin_view_look_straight();
  1063. tween(view.architectural, 0.0, distance(1.0,0.5));
  1064. tween(view.pannini, 0.0, distance(1.0,0.5));
  1065. tween(view.distortion, 1.0, distance(1.0,0.8));
  1066. </action>
  1067. <action name="skin_view_pannini">
  1068. skin_view_look_straight();
  1069. tween(view.architectural, 0.0, distance(1.0,0.5));
  1070. tween(view.pannini, 1.0, distance(1.0,0.8));
  1071. if(view.distortion LT 0.1,
  1072. tween(view.distortion, 1.0, distance(1.0,0.8));
  1073. );
  1074. </action>
  1075. <action name="skin_view_littleplanet">
  1076. tween(view.architectural, 0.0, distance(1.0,0.5));
  1077. tween(view.pannini, 0.0, distance(1.0,0.5));
  1078. tween(view.distortion, 1.0, distance(1.0,0.8));
  1079. tween(view.fov, 150, distance(150,0.8));
  1080. tween(view.vlookat, 90, distance(100,0.8));
  1081. tween(view.hlookat, calc(view.hlookat + 100.0 + 45.0*random), distance(100,0.8));
  1082. skin_deeplinking_update_url(1.0);
  1083. </action>
  1084. <action name="skin_followmouse_init" scope="private:skinfollowmouse" autorun="onstart" devices="desktop.and.no-touch">
  1085. if(global.skin_settings.followmousecontrol,
  1086. set(followspeed, 0.05);
  1087. set(followrange, 10);
  1088. set(followfactor, 1.0);
  1089. set(track_ry, 0);
  1090. set(track_rx, 0);
  1091. set(global.events[skin_followmouse].keep, true);
  1092. set(global.events[skin_followmouse].onviewchanged, set(global.view.haschanged,true); );
  1093. set(global.events[skin_followmouse].onviewchange, skin_followmouse_onviewchange() );
  1094. set(global.events[skin_followmouse].onmousedown, scope(private:skinfollowmouse, stopdelayedcall(followmouse_reenable); tween(followfactor,0.0,0.2); ); );
  1095. set(global.events[skin_followmouse].onmouseup, scope(private:skinfollowmouse, delayedcall(followmouse_reenable, 1.0, tween(followfactor,1.0,3.0) ); ); );
  1096. );
  1097. </action>
  1098. <action name="skin_followmouse_onviewchange" scope="private:skinfollowmouse">
  1099. if(global.mouse.x != 0 AND global.mouse.y != 0,
  1100. Math.tan(zoomscale, calc(global.view.vfov * 0.5 * Math.PI / 180.0));
  1101. calc(zoomscale, 1.0 / zoomscale);
  1102. Math.max(zoomscale, 1.0);
  1103. calc(new_ry, followfactor/zoomscale * followrange * (global.mouse.x / global.stagewidth - 0.5));
  1104. calc(new_rx, followfactor/zoomscale * followrange * (global.mouse.y / global.stageheight - 0.5));
  1105. calc(track_ry, track_ry*(1.0-followspeed) + new_ry*followspeed);
  1106. calc(track_rx, track_rx*(1.0-followspeed) + new_rx*followspeed);
  1107. copy(global.view.ry, track_ry);
  1108. copy(global.view.rx, track_rx);
  1109. );
  1110. </action>
  1111. <!-- A helper script for getting into fullscreen mode on the iPhone. -->
  1112. <events name="iphone_fullscreen_swipe" keep="true" devices="iphone"
  1113. oniphonefullscreen="iphone_fullscreen_swipe();"
  1114. />
  1115. <action name="iphone_fullscreen_swipe" scope="localonly">
  1116. if(global.display.iphonefullscreen GT 0,
  1117. if(!global.layer[iphone_fullscreen_info],
  1118. addlayer('iphone_fullscreen_info', infolayer);
  1119. set(infolayer, type=text, css='color:#FFFFFF; font-size:26px; font-weight:bold; text-align:center;', txtshadow='0 0 8 0x000000 1', mergedalpha=false, bgcolor=0x000000, bgalpha=0.7, bgcapture=true, align=lefttop, x=0, y=0, width=100%, height=100%, vcenter=true, keep=true, zorder=9999, safearea=false);
  1120. if(global.display.iphonefullscreen == 1,
  1121. set(infolayer.html, '[span style="font-size:60px;"]⇡[/span][br]Swipe Up');
  1122. ,
  1123. set(infolayer.html, '[span style="font-size:60px;"]⇣ ⇡[/span][br]Swipe Down and Up');
  1124. );
  1125. );
  1126. ,
  1127. removelayer('iphone_fullscreen_info');
  1128. );
  1129. </action>
  1130. </krpano>