Loading content, please wait..
           
 

1. 美聯儲官員梅斯特爾預計今年利率略微上升 - 华尔街日报    2. 德國2月份經濟預期略微改善    3. 日本1月份貿易逆差創五年新高    4. 老齡化的日本如何扛住了人口挑戰,重振經濟?    5. 德國央行:無跡象顯示德國經濟放緩正在變成一場衰退    6. 澳洲央行對消費支出增長放緩感到擔憂    7. 中國央行:很快會進行首次央行票據互換工具操作    8. 雖退歐相關不安情緒仍存,英國去年年末仍實現就業增長    9. 本周全球經濟大事    10. 一些經濟學家認為無需擔心美國債務問題    11. 美聯儲理事佈雷納德稱縮表進程或於今年結束    12. 美國去年12月零售額降幅創九年來最大    13. 中國1月份PPI同比增速創2016年9月以來新低    14. 貿易摩擦阻礙德國和日本經濟增長    15. 中國1月份CPI同比增速創一年低點    16. 中國1月份人民幣新增貸款和社融規模增量齊創紀錄    17. 中國通脹數據低迷或刺激政策放鬆 - 华尔街日报    18. 美聯儲官員哈克預期今明兩年各加息一次    19. 美國2018年稅收收入減少,新稅法生效後赤字擴大    20. 歐元區去年12月工業產值創九年最大降幅   
  公開資訊觀測站 | 證券櫃檯買賣中心 | 興櫃即時行情      

EMail:
密碼:
認證碼:
記住EMail
忘記密碼
免費加入會員
 
 
line
 
 
長紅未上市股票資訊網 > 最新消息  
 
 

cn.wsj.com


cn.wsj.com /* Copyright 2017 The Chromium Authors. All rights reserved. * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */a { color: rgb(88, 88, 88);}body { --google-blue-600: #1A73E8; --google-blue-700: #1967D2; background-color: #fff; color: rgb(100, 100, 100); word-wrap: break-word;}#details-button { background: inherit; border: 0; float: none; margin: 0; padding: 10px 0; text-transform: uppercase;}.hidden { display: none;}html { -webkit-text-size-adjust: 100%; font-size: 125%;}.icon { background-repeat: no-repeat; background-size: 100%;} /* Copyright 2014 The Chromium Authors. All rights reserved. Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. */button { border: 0; border-radius: 4px; box-sizing: border-box; color: #fff; cursor: pointer; float: right; font-size: .875em; margin: 0; padding: 10px 24px; transition: box-shadow 200ms cubic-bezier(0.4, 0, 0.2, 1); user-select: none;}[dir='rtl'] button { float: left;}.bad-clock button,.captive-portal button,.main-frame-blocked button,.neterror button,.offline button,.pdf button,.ssl button,.safe-browsing-billing button { background: var(--google-blue-600);}button:active { background: var(--google-blue-700); outline: 0;}button:hover { box-shadow: 0 1px 3px rgba(0, 0, 0, .50);}#debugging { display: inline; overflow: auto;}.debugging-content { line-height: 1em; margin-bottom: 0; margin-top: 1em;}.debugging-content-fixed-width { display: block; font-family: monospace; font-size: 1.2em; margin-top: 0.5em;}.debugging-title { font-weight: bold;}#details { color: #696969; margin: 0 0 50px;}#details p:not(:first-of-type) { margin-top: 20px;}#details-button:hover { box-shadow: inherit; text-decoration: underline;}.error-code { color: #646464; font-size: .86667em; text-transform: uppercase; margin-top: 12px;}#error-debugging-info { font-size: 0.8em;}h1 { color: #333; font-size: 1.6em; font-weight: normal; line-height: 1.25em; margin-bottom: 16px;}h2 { font-size: 1.2em; font-weight: normal;}.icon { height: 72px; margin: 0 0 40px; width: 72px;}input[type=checkbox] { opacity: 0;}input[type=checkbox]:focus ~ .checkbox { outline: -webkit-focus-ring-color auto 5px;}.interstitial-wrapper { box-sizing: border-box; font-size: 1em; line-height: 1.6em; margin: 14vh auto 0; max-width: 600px; width: 100%;}#main-message > p { display: inline;}#extended-reporting-opt-in { font-size: .875em; margin-top: 39px;}#extended-reporting-opt-in label { position: relative; display: flex; align-items: flex-start;}.nav-wrapper { margin-top: 51px;}.nav-wrapper::after { clear: both; content: ''; display: table; width: 100%;}.small-link { color: #696969; font-size: .875em;}.checkboxes { flex: 0 0 24px;}.checkbox { background: transparent; border: 1px solid white; border-radius: 2px; display: block; height: 14px; left: 0; position: absolute; right: 0; top: 3px; width: 14px;}.checkbox::before { background: transparent; border: 2px solid white; border-right-width: 0; border-top-width: 0; content: ''; height: 4px; left: 2px; opacity: 0; position: absolute; top: 3px; transform: rotate(-45deg); width: 9px;}input[type=checkbox]:checked ~ .checkbox::before { opacity: 1;}#recurrent-error-message { background: #ededed; border-radius: 4px; padding: 12px 16px; margin-top: 12px; margin-bottom: 16px;}.showing-recurrent-error-message #extended-reporting-opt-in { margin-top: 16px;}@media (max-width: 700px) { .interstitial-wrapper { padding: 0 10%; } #error-debugging-info { overflow: auto; }}@media (max-width: 420px) { button, [dir='rtl'] button, .small-link { float: none; font-size: .825em; font-weight: 400; margin: 0; text-transform: uppercase; width: 100%; } #details { margin: 20px 0 20px 0; } #details p:not(:first-of-type) { margin-top: 10px; } #details-button { display: block; margin-top: 20px; text-align: center; width: 100%; } .interstitial-wrapper { padding: 0 5%; } #extended-reporting-opt-in { margin-top: 24px; } .nav-wrapper { margin-top: 30px; }}/** * Mobile specific styling. * Navigation buttons are anchored to the bottom of the screen. * Details message replaces the top content in its own scrollable area. */@media (max-width: 420px) { #details-button { border: 0; margin: 8px 0 0; } .secondary-button { margin-inline-end: 0; margin-top: 16px; }}/* Fixed nav. */@media (min-width: 240px) and (max-width: 420px) and (min-height: 401px), (min-width: 421px) and (min-height: 240px) and (max-height: 560px) { body .nav-wrapper { background: #fff; bottom: 0; box-shadow: 0 -22px 40px #fff; left: 0; margin: 0 auto; max-width: 736px; padding-left: 24px; padding-right: 24px; position: fixed; right: 0; width: 100%; z-index: 2; } .interstitial-wrapper { max-width: 736px; } #details, #main-content { padding-bottom: 40px; } #details { padding-top: 5.5vh; } #details-button:hover { box-shadow: none; } button { padding: 16px 24px; } button.small-link { color: var(--google-blue-600); }}@media (max-width: 420px) and (orientation: portrait), (max-height: 560px) { body { margin: 0 auto; } button, [dir='rtl'] button, button.small-link { font-family: Roboto-Regular,Helvetica; font-size: .933em; font-weight: 600; margin: 6px 0; text-transform: uppercase; transform: translatez(0); } .nav-wrapper { box-sizing: border-box; padding-bottom: 8px; width: 100%; } #details { box-sizing: border-box; height: auto; margin: 0; opacity: 1; transition: opacity 250ms cubic-bezier(0.4, 0, 0.2, 1); } #details.hidden, #main-content.hidden { display: block; height: 0; opacity: 0; overflow: hidden; padding-bottom: 0; transition: none; } #details-button { padding-bottom: 16px; padding-top: 16px; } h1 { font-size: 1.5em; margin-bottom: 8px; } .icon { margin-bottom: 5.69vh; } .interstitial-wrapper { box-sizing: border-box; margin: 7vh auto 12px; padding: 0 24px; position: relative; } .interstitial-wrapper p { font-size: .95em; line-height: 1.61em; margin-top: 8px; } #main-content { margin: 0; transition: opacity 100ms cubic-bezier(0.4, 0, 0.2, 1); } .small-link { border: 0; } .suggested-left > #control-buttons, .suggested-right > #control-buttons { float: none; margin: 0; }}@media (min-width: 421px) and (min-height: 500px) and (max-height: 560px) { .interstitial-wrapper { margin-top: 10vh; }}@media (min-height: 400px) and (orientation:portrait) { .interstitial-wrapper { margin-bottom: 145px; }}@media (min-height: 299px) { .nav-wrapper { padding-bottom: 16px; }}@media (min-height: 500px) and (max-height: 650px) and (max-width: 414px) and (orientation: portrait) { .interstitial-wrapper { margin-top: 7vh; }}@media (min-height: 650px) and (max-width: 414px) and (orientation: portrait) { .interstitial-wrapper { margin-top: 10vh; }}/* Small mobile screens. No fixed nav. */@media (max-height: 400px) and (orientation: portrait), (max-height: 239px) and (orientation: landscape), (max-width: 419px) and (max-height: 399px) { .interstitial-wrapper { display: flex; flex-direction: column; margin-bottom: 0; } #details { flex: 1 1 auto; order: 0; } #main-content { flex: 1 1 auto; order: 0; } .nav-wrapper { flex: 0 1 auto; margin-top: 8px; order: 1; padding-left: 0; padding-right: 0; position: relative; width: 100%; } button { padding: 16px 24px; } button.small-link { color: var(--google-blue-600); }}@media (max-width: 239px) and (orientation: portrait) { .nav-wrapper { padding-left: 0; padding-right: 0; }} /* Copyright 2013 The Chromium Authors. All rights reserved. * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. *//* Don't use the main frame div when the error is in a subframe. */html[subframe] #main-frame-error { display: none;}/* Don't use the subframe error div when the error is in a main frame. */html:not([subframe]) #sub-frame-error { display: none;}#diagnose-button { float: none; margin-bottom: 10px; margin-inline-start: 0; margin-top: 20px;}h1 { margin-top: 0; word-wrap: break-word;}h1 span { font-weight: 500;}h2 { color: #666; font-size: 1.2em; font-weight: normal; margin: 10px 0;}a { color: rgb(17, 85, 204); text-decoration: none;}.icon { -webkit-user-select: none; display: inline-block;}.icon-generic { /** * Can't access chrome://theme/IDR_ERROR_NETWORK_GENERIC from an untrusted * renderer process, so embed the resource manually. */ content: -webkit-image-set( url() 1x, url() 2x);}.icon-offline { content: -webkit-image-set( url() 1x, url() 2x); position: relative;}.icon-disabled { content: -webkit-image-set( url() 1x, url() 2x); width: 112px;}.error-code { display: block; font-size: .8em;}#content-top { margin: 20px;}#help-box-inner { background-color: #f9f9f9; border-top: 1px solid #EEE; color: #444; padding: 20px; text-align: start;}.hidden { display: none;}#suggestion { margin-top: 15px;}#suggestions-list p { margin-block-end: 0;}#suggestions-list ul { margin-top: 0;}.single-suggestion { list-style-type: none; padding-left: 0;}#short-suggestion { margin-top: 5px;}#error-information-button { content: -webkit-image-set( url() 1x, url() 2x); height: 24px; vertical-align: -.15em; width: 24px;}.use-popup-container#error-information-popup-container #error-information-popup { align-items: center; background-color: rgba(0,0,0,.65); display: flex; height: 100%; left: 0; position: fixed; top: 0; width: 100%; z-index: 100;}.use-popup-container#error-information-popup-container #error-information-popup-content > p { margin-bottom: 11px; margin-inline-start: 20px;}.use-popup-container#error-information-popup-container #suggestions-list ul { margin-inline-start: 15px;}.use-popup-container#error-information-popup-container #error-information-popup-box { background-color: white; left: 5%; padding-bottom: 15px; padding-top: 15px; position: fixed; width: 90%; z-index: 101;}.use-popup-container#error-information-popup-container div.error-code { margin-inline-start: 20px;}.use-popup-container#error-information-popup-container #suggestions-list p { margin-inline-start: 20px;}:not(.use-popup-container)#error-information-popup-container #error-information-popup-close { display: none;}#error-information-popup-close { margin-bottom: 0px; margin-inline-end: 35px; margin-top: 15px; text-align: end;}.link-button { color: rgb(66, 133, 244); display: inline-block; font-weight: bold; text-transform: uppercase;}#sub-frame-error-details { color: #8F8F8F; /* Not done on mobile for performance reasons. */ text-shadow: 0 1px 0 rgba(255,255,255,0.3);}[jscontent=hostName],[jscontent=failedUrl] { overflow-wrap: break-word;}#search-container { /* Prevents a space between controls. */ display: flex; margin-top: 20px;}#search-box { border: 1px solid #cdcdcd; flex-grow: 1; font-size: 1em; height: 26px; margin-right: 0; padding: 1px 9px;}#search-box:focus { border: 1px solid rgb(93, 154, 255); outline: none;}#search-button { border: none; border-bottom-left-radius: 0; border-top-left-radius: 0; box-shadow: none; display: flex; height: 30px; margin: 0; padding: 0; width: 60px;}#search-image { content: -webkit-image-set( url() 1x, url() 2x); margin: auto;}.secondary-button { background: #d9d9d9; color: #696969; margin-inline-end: 16px;}.snackbar { background: #323232; border-radius: 2px; bottom: 24px; box-sizing: border-box; color: #fff; font-size: .87em; left: 24px; max-width: 568px; min-width: 288px; opacity: 0; padding: 16px 24px 12px; position: fixed; transform: translateY(90px); will-change: opacity, transform; z-index: 999;}.snackbar-show { -webkit-animation: show-snackbar .25s cubic-bezier(0.0, 0.0, 0.2, 1) forwards, hide-snackbar .25s cubic-bezier(0.4, 0.0, 1, 1) forwards 5s;}@-webkit-keyframes show-snackbar { 100% { opacity: 1; transform: translateY(0); }}@-webkit-keyframes hide-snackbar { 0% { opacity: 1; transform: translateY(0); } 100% { opacity: 0; transform: translateY(90px); }}.suggestions { margin-top: 18px;}.suggestion-header { font-weight: bold; margin-bottom: 4px;}.suggestion-body { color: #777;}/* Increase line height at higher resolutions. */@media (min-width: 641px) and (min-height: 641px) { #help-box-inner { line-height: 18px; }}/* Decrease padding at low sizes. */@media (max-width: 640px), (max-height: 640px) { h1 { margin: 0 0 15px; } #content-top { margin: 15px; } #help-box-inner { padding: 20px; } .suggestions { margin-top: 10px; } .suggestion-header { margin-bottom: 0; }}#download-link, #download-link-clicked { margin-bottom: 15px;}#download-link-clicked { color: #BBB;}#download-link:before, #download-link-clicked:before { content: url(); display: inline-block; margin-inline-end: 4px; vertical-align: -webkit-baseline-middle;}#download-link-clicked:before { width: 0px; opacity: 0;}.offline-content-suggestion-image { height: 35vw; line-height: 0; width: 35vw; flex-basis: 35vw; flex-grow: 0; flex-shrink: 0;}.offline-content-suggestion-image > img { border-bottom-left-radius: 15px; border-top-left-radius: 15px; height: 35vw; line-height: 0; width: 35vw;}.offline-content-suggestion-title { -webkit-box-orient: vertical; -webkit-line-clamp: 3; display: -webkit-box; margin: 5%; max-height: 65px; overflow: hidden; text-overflow: ellipsis;}.offline-content-suggestion-freshness, .offline-content-suggestion-attribution { color: #646464; display: inline-block; font-size: small; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;}.offline-content-suggestion-attribution { margin-left: 5%; max-width: 35%; overflow: hidden; white-space: nowrap;}div.offline-content-suggestion { background-color: rgb(241, 243, 244); border-radius: 15px; display: flex; margin-bottom: 5%; margin-left: 0; margin-right: 0; margin-top: 5%;}#offline-content-summary { border-color: rgb(241, 243, 244); border-radius: 12px; border-style: solid; border-width: 1px; padding: 12px; text-align: center;}.offline-content-summary-image-truncate { width: 45px;}.offline-content-summary-images { direction: ltr; display: flex; margin-top: 10px; justify-content: center; padding-bottom: 12px;}.offline-content-summary-images img { background: rgb(241, 243, 244); border-radius: 50%; box-shadow: 0px 1px 2px 0px rgb(155, 155, 155), 0px 1px 3px 0px rgb(155, 155, 155); padding: 12px; width: 32px;}.offline-content-summary-description { border-top: 1px solid rgb(241, 243, 244); padding-top: 12px;}.offline-content-summary-action { padding-top: 12px;}/* Don't allow overflow when in a subframe. */html[subframe] body { overflow: hidden;}#sub-frame-error { -webkit-align-items: center; background-color: #DDD; display: -webkit-flex; -webkit-flex-flow: column; height: 100%; -webkit-justify-content: center; left: 0; position: absolute; text-align: center; top: 0; transition: background-color .2s ease-in-out; width: 100%;}#sub-frame-error:hover { background-color: #EEE;}#sub-frame-error .icon-generic { margin: 0 0 16px;}#sub-frame-error-details { margin: 0 10px; text-align: center; visibility: hidden;}/* Show details only when hovering. */#sub-frame-error:hover #sub-frame-error-details { visibility: visible;}/* If the iframe is too small, always hide the error code. *//* TODO(mmenke): See if overflow: no-display works better, once supported. */@media (max-width: 200px), (max-height: 95px) { #sub-frame-error-details { display: none; }}/* Adjust icon for small embedded frames in apps. */@media (max-height: 100px) { #sub-frame-error .icon-generic { height: auto; margin: 0; padding-top: 0; width: 25px; }}/* details-button is special; it's a <button> element that looks like a link. */#details-button { box-shadow: none; min-width: 0;}/* Styles for platform dependent separation of controls and details button. */.suggested-left > #control-buttons,.suggested-left #stale-load-button,.suggested-right > #details-button { float: left;}.suggested-right > #control-buttons,.suggested-right #stale-load-button,.suggested-left > #details-button { float: right;}.suggested-left .secondary-button { margin-inline-end: 0px; margin-inline-start: 16px;}#details-button.singular { float: none;}/* download-button shows both icon and text. */#download-button { height: 48px;}#download-button { box-shadow: none; position: relative;}#download-button:before { background: -webkit-image-set( url() 1x, url() 2x) no-repeat; content: ''; display: inline-block; width: 24px; height: 24px; margin-inline-end: 4px; vertical-align: middle;}#download-button:disabled { background: rgb(180, 206, 249); color: rgb(255, 255, 255);}/*TODO(https://crbug.com/852872): UI for offline suggested content is incomplete.*/.suggested-thumbnail { width: 25vw; height: 25vw;}/* Alternate dino page button styles */#control-buttons .reload-button-alternate:disabled { background: #ccc; color: #fff; font-size: 14px; height: 48px;}#buttons::after { clear: both; content: ''; display: block; width: 100%;}/* Offline page */.offline { transition: -webkit-filter 1.5s cubic-bezier(0.65, 0.05, 0.36, 1), background-color 1.5s cubic-bezier(0.65, 0.05, 0.36, 1); will-change: -webkit-filter, background-color;}.offline #main-message > p { display: none;}.offline.inverted { -webkit-filter: invert(100%); background-color: #000;}.offline .interstitial-wrapper { color: #2b2b2b; font-size: 1em; line-height: 1.55; margin: 0 auto; max-width: 600px; padding-top: 100px; width: 100%;}.offline .runner-container { direction: ltr; height: 150px; max-width: 600px; overflow: hidden; position: absolute; top: 35px; width: 44px;}.offline .runner-canvas { height: 150px; max-width: 600px; opacity: 1; overflow: hidden; position: absolute; top: 0; z-index: 10;}.offline .controller { background: rgba(247,247,247, .1); height: 100vh; left: 0; position: absolute; top: 0; width: 100vw; z-index: 9;}#offline-resources { display: none;}@media (max-width: 420px) { .suggested-left > #control-buttons, .suggested-right > #control-buttons { float: none; } .snackbar { left: 0; bottom: 0; width: 100%; border-radius: 0; }}@media (max-height: 350px) { h1 { margin: 0 0 15px; } .icon-offline { margin: 0 0 10px; } .interstitial-wrapper { margin-top: 5%; } .nav-wrapper { margin-top: 30px; }}@media (min-width: 420px) and (max-width: 736px) and (min-height: 240px) and (max-height: 420px) and (orientation:landscape) { .interstitial-wrapper { margin-bottom: 100px; }}@media (max-width: 360px) and (max-height: 480px) { .offline .interstitial-wrapper { padding-top: 60px; } .offline .runner-container { top: 8px; }}@media (min-height: 240px) and (orientation: landscape) { .offline .interstitial-wrapper { margin-bottom: 90px; } .icon-offline { margin-bottom: 20px; }}@media (max-height: 320px) and (orientation: landscape) { .icon-offline { margin-bottom: 0; } .offline .runner-container { top: 10px; }}@media (max-width: 240px) { button { padding-left: 12px; padding-right: 12px; } .interstitial-wrapper { overflow: inherit; padding: 0 8px; }}@media (max-width: 120px) { button { width: auto; }}.arcade-mode,.arcade-mode .runner-container,.arcade-mode .runner-canvas { image-rendering: pixelated; max-width: 100%; overflow: hidden;}.arcade-mode #buttons,.arcade-mode #main-content { opacity: 0; overflow: hidden;}.arcade-mode .interstitial-wrapper { height: 100vh; max-width: 100%; overflow: hidden;}.arcade-mode .runner-container { left: 0; margin: auto; right: 0; transform-origin: top center; transition: transform 250ms cubic-bezier(0.4, 0.0, 1, 1) .4s; z-index: 2;} // Copyright 2017 The Chromium Authors. All rights reserved.// Use of this source code is governed by a BSD-style license that can be// found in the LICENSE file.// This is the shared code for security interstitials. It is used for both SSL// interstitials and Safe Browsing interstitials.// Should match security_interstitials::SecurityInterstitialCommand/** @enum| {string} */var SecurityInterstitialCommandId = { CMD_DONT_PROCEED: 0, CMD_PROCEED: 1, // Ways for user to get more information CMD_SHOW_MORE_SECTION: 2, CMD_OPEN_HELP_CENTER: 3, CMD_OPEN_DIAGNOSTIC: 4, // Primary button actions CMD_RELOAD: 5, CMD_OPEN_DATE_SETTINGS: 6, CMD_OPEN_LOGIN: 7, // Safe Browsing Extended Reporting CMD_DO_REPORT: 8, CMD_DONT_REPORT: 9, CMD_OPEN_REPORTING_PRIVACY: 10, CMD_OPEN_WHITEPAPER: 11, // Report a phishing error. CMD_REPORT_PHISHING_ERROR: 12};var HIDDEN_CLASS = 'hidden';/** * A convenience method for sending commands to the parent page. * @param {string} cmd The command to send. */function sendCommand(cmd) { if (window.certificateErrorPageController) { switch (cmd) { case SecurityInterstitialCommandId.CMD_DONT_PROCEED: certificateErrorPageController.dontProceed(); break; case SecurityInterstitialCommandId.CMD_PROCEED: certificateErrorPageController.proceed(); break; case SecurityInterstitialCommandId.CMD_SHOW_MORE_SECTION: certificateErrorPageController.showMoreSection(); break; case SecurityInterstitialCommandId.CMD_OPEN_HELP_CENTER: certificateErrorPageController.openHelpCenter(); break; case SecurityInterstitialCommandId.CMD_OPEN_DIAGNOSTIC: certificateErrorPageController.openDiagnostic(); break; case SecurityInterstitialCommandId.CMD_RELOAD: certificateErrorPageController.reload(); break; case SecurityInterstitialCommandId.CMD_OPEN_DATE_SETTINGS: certificateErrorPageController.openDateSettings(); break; case SecurityInterstitialCommandId.CMD_OPEN_LOGIN: certificateErrorPageController.openLogin(); break; case SecurityInterstitialCommandId.CMD_DO_REPORT: certificateErrorPageController.doReport(); break; case SecurityInterstitialCommandId.CMD_DONT_REPORT: certificateErrorPageController.dontReport(); break; case SecurityInterstitialCommandId.CMD_OPEN_REPORTING_PRIVACY: certificateErrorPageController.openReportingPrivacy(); break; case SecurityInterstitialCommandId.CMD_OPEN_WHITEPAPER: certificateErrorPageController.openWhitepaper(); break; case SecurityInterstitialCommandId.CMD_REPORT_PHISHING_ERROR: certificateErrorPageController.reportPhishingError(); break; } return; }// window.domAutomationController.send(cmd);// // }/** * Call this to stop clicks on <a href="#"> links from scrolling to the top of * the page (and possibly showing a # in the link). */function preventDefaultOnPoundLinkClicks() { document.addEventListener('click', function(e) { var anchor = findAncestor(/** @type {Node} */ (e.target), function(el) { return el.tagName == 'A'; }); // Use getAttribute() to prevent URL normalization. if (anchor && anchor.getAttribute('href') == '#') e.preventDefault(); });} // Copyright 2015 The Chromium Authors. All rights reserved.// Use of this source code is governed by a BSD-style license that can be// found in the LICENSE file.var mobileNav = false;/** * For small screen mobile the navigation buttons are moved * below the advanced text. */function onResize() { var helpOuterBox = document.querySelector('#details'); var mainContent = document.querySelector('#main-content'); var mediaQuery = '(min-width: 240px) and (max-width: 420px) and ' + '(min-height: 401px), ' + '(max-height: 560px) and (min-height: 240px) and ' + '(min-width: 421px)'; var detailsHidden = helpOuterBox.classList.contains(HIDDEN_CLASS); var runnerContainer = document.querySelector('.runner-container'); // Check for change in nav status. if (mobileNav != window.matchMedia(mediaQuery).matches) { mobileNav = !mobileNav; // Handle showing the top content / details sections according to state. if (mobileNav) { mainContent.classList.toggle(HIDDEN_CLASS, !detailsHidden); helpOuterBox.classList.toggle(HIDDEN_CLASS, detailsHidden); if (runnerContainer) { runnerContainer.classList.toggle(HIDDEN_CLASS, !detailsHidden); } } else if (!detailsHidden) { // Non mobile nav with visible details. mainContent.classList.remove(HIDDEN_CLASS); helpOuterBox.classList.remove(HIDDEN_CLASS); if (runnerContainer) { runnerContainer.classList.remove(HIDDEN_CLASS); } } }}function setupMobileNav() { window.addEventListener('resize', onResize); onResize();}document.addEventListener('DOMContentLoaded', setupMobileNav); // Copyright 2013 The Chromium Authors. All rights reserved.// Use of this source code is governed by a BSD-style license that can be// found in the LICENSE file.function toggleHelpBox() { var helpBoxOuter = document.getElementById('details'); helpBoxOuter.classList.toggle(HIDDEN_CLASS); var detailsButton = document.getElementById('details-button'); if (helpBoxOuter.classList.contains(HIDDEN_CLASS)) detailsButton.innerText = detailsButton.detailsText; else detailsButton.innerText = detailsButton.hideDetailsText; // Details appears over the main content on small screens. if (mobileNav) { document.getElementById('main-content').classList.toggle(HIDDEN_CLASS); var runnerContainer = document.querySelector('.runner-container'); if (runnerContainer) { runnerContainer.classList.toggle(HIDDEN_CLASS); } }}function diagnoseErrors() {// if (window.errorPageController) errorPageController.diagnoseErrorsButtonClick();// // }// Subframes use a different layout but the same html file. This is to make it// easier to support platforms that load the error page via different// mechanisms (Currently just iOS).if (window.top.location != window.location) document.documentElement.setAttribute('subframe', '');// Re-renders the error page using |strings| as the dictionary of values.// Used by NetErrorTabHelper to update DNS error pages with probe results.function updateForDnsProbe(strings) { var context = new JsEvalContext(strings); jstProcess(context, document.getElementById('t'));}// Given the classList property of an element, adds an icon class to the list// and removes the previously-function updateIconClass(classList, newClass) { var oldClass; if (classList.hasOwnProperty('last_icon_class')) { oldClass = classList['last_icon_class']; if (oldClass == newClass) return; } classList.add(newClass); if (oldClass !== undefined) classList.remove(oldClass); classList['last_icon_class'] = newClass; if (newClass == 'icon-offline') { document.body.classList.add('offline'); new Runner('.interstitial-wrapper'); } else { document.body.classList.add('neterror'); }}// Does a search using |baseSearchUrl| and the text in the search box.function search(baseSearchUrl) { var searchTextNode = document.getElementById('search-box'); document.location = baseSearchUrl + searchTextNode.value; return false;}// Use to track clicks on elements generated by the navigation correction// service. If |trackingId| is negative, the element does not come from the// correction service.function trackClick(trackingId) { // This can't be done with XHRs because XHRs are cancelled on navigation // start, and because these are cross-site requests. if (trackingId >= 0 && errorPageController) errorPageController.trackClick(trackingId);}// Called when an <a> tag generated by the navigation correction service is// clicked. Separate function from trackClick so the resources don't have to// be updated if new data is added to jstdata.function linkClicked(jstdata) { trackClick(jstdata.trackingId);}// Implements button clicks. This function is needed during the transition// between implementing these in trunk chromium and implementing them in// iOS.function reloadButtonClick(url) { if (window.errorPageController) { errorPageController.reloadButtonClick(); } else { location = url; }}function showSavedCopyButtonClick() { if (window.errorPageController) { errorPageController.showSavedCopyButtonClick(); }}function downloadButtonClick() { if (window.errorPageController) { errorPageController.downloadButtonClick(); var downloadButton = document.getElementById('download-button'); downloadButton.disabled = true; downloadButton.textContent = downloadButton.disabledText; document.getElementById('download-link-wrapper') .classList.add(HIDDEN_CLASS); document.getElementById('download-link-clicked-wrapper') .classList.remove(HIDDEN_CLASS); }}function detailsButtonClick() { if (window.errorPageController) errorPageController.detailsButtonClick();}/** * Replace the reload button with the Google cached copy suggestion. */function setUpCachedButton(buttonStrings) { var reloadButton = document.getElementById('reload-button'); reloadButton.textContent = buttonStrings.msg; var url = buttonStrings.cacheUrl; var trackingId = buttonStrings.trackingId; reloadButton.onclick = function(e) { e.preventDefault(); trackClick(trackingId); if (window.errorPageController) { errorPageController.trackCachedCopyButtonClick(); } location = url; }; reloadButton.style.display = ''; document.getElementById('control-buttons').hidden = false;}var primaryControlOnLeft = true;// function toggleErrorInformationPopup() { document.getElementById('error-information-popup-container') .classList.toggle(HIDDEN_CLASS);}function getSuggestedContentDiv(item) { var visual = ''; if (item.thumbnail_data_uri) { // html_inline.py will try to replace src attributes with data URIs using // a simple regex. The following is obfuscated slightly to avoid that. var src = 'src'; visual = `<img ${src}="${item.thumbnail_data_uri}">`; } return `<div class="offline-content-suggestion" onclick="launchOfflineItem('${item.ID}', '${item.name_space}')"> <div class="offline-content-suggestion-image">${visual}</div> <div> <div class="offline-content-suggestion-title">${item.title}</div> <span class="offline-content-suggestion-attribution">${ item.attribution }</span> <span class="offline-content-suggestion-freshness">${ item.date_modified }</span> </div></div>`;}function launchOfflineItem(itemID, name_space) { errorPageController.launchOfflineItem(itemID, name_space);}function launchDownloadsPage() { errorPageController.launchDownloadsPage();}// Populates a summary of suggested offline content.function offlineContentSummaryAvailable(summary) { if (!summary || !loadTimeData.valueExists('offlineContentSummary')) return; document.getElementById('offline-content-summary').hidden = false;}// Populates a list of suggested offline content.// TODO(https://crbug.com/852872): Finish implementing offline content list UI.function offlineContentAvailable(content) { if (!content || !loadTimeData.valueExists('offlineContentList')) return; var contentTitle = loadTimeData.getValue('offlineContentList').title; var contentOpenAllButton = loadTimeData.getValue('offlineContentList').actionText; var suggestionsHTML = []; suggestionsHTML.push(`<p style="text-align: center;">${contentTitle}</p>`); for (var c of content) suggestionsHTML.push(getSuggestedContentDiv(c)); suggestionsHTML.push(`<div> <a class="link-button" onclick="launchDownloadsPage()">${ contentOpenAllButton }</a></div>`); var offlineContentDiv = document.getElementById('offline-content-list'); offlineContentDiv.innerHTML = suggestionsHTML.join('n'); offlineContentDiv.hidden = false;}function onDocumentLoad() { var controlButtonDiv = document.getElementById('control-buttons'); var reloadButton = document.getElementById('reload-button'); var detailsButton = document.getElementById('details-button'); var showSavedCopyButton = document.getElementById('show-saved-copy-button'); var downloadButton = document.getElementById('download-button'); var reloadButtonVisible = loadTimeData.valueExists('reloadButton') && loadTimeData.getValue('reloadButton').msg; var showSavedCopyButtonVisible = loadTimeData.valueExists('showSavedCopyButton') && loadTimeData.getValue('showSavedCopyButton').msg; var downloadButtonVisible = loadTimeData.valueExists('downloadButton') && loadTimeData.getValue('downloadButton').msg; // If offline content suggestions will be visible, the usual buttons will not // be presented. var offlineContentVisible = loadTimeData.valueExists('suggestedOfflineContentPresentationMode'); if (offlineContentVisible) { document.querySelector('.nav-wrapper').classList.add(HIDDEN_CLASS); detailsButton.classList.add(HIDDEN_CLASS); if (downloadButtonVisible) document.getElementById('download-link').hidden = false; document.getElementById('download-links-wrapper') .classList.remove(HIDDEN_CLASS); document.getElementById('error-information-popup-container') .classList.add('use-popup-container', HIDDEN_CLASS) document.getElementById('error-information-button') .classList.remove(HIDDEN_CLASS); return; } var primaryButton, secondaryButton; if (showSavedCopyButton.primary) { primaryButton = showSavedCopyButton; secondaryButton = reloadButton; } else { primaryButton = reloadButton; secondaryButton = showSavedCopyButton; } // Sets up the proper button layout for the current platform. if (primaryControlOnLeft) { buttons.classList.add('suggested-left'); controlButtonDiv.insertBefore(secondaryButton, primaryButton); } else { buttons.classList.add('suggested-right'); controlButtonDiv.insertBefore(primaryButton, secondaryButton); } // Check for Google cached copy suggestion. if (loadTimeData.valueExists('cacheButton')) { setUpCachedButton(loadTimeData.getValue('cacheButton')); } if (reloadButton.style.display == 'none' && showSavedCopyButton.style.display == 'none' && downloadButton.style.display == 'none') { detailsButton.classList.add('singular'); } // Show control buttons. if (reloadButtonVisible || showSavedCopyButtonVisible || downloadButtonVisible) { controlButtonDiv.hidden = false; // Set the secondary button state in the cases of two call to actions. if ((reloadButtonVisible || downloadButtonVisible) && showSavedCopyButtonVisible) { secondaryButton.classList.add('secondary-button'); } }}document.addEventListener('DOMContentLoaded', onDocumentLoad); // Copyright (c) 2014 The Chromium Authors. All rights reserved.// Use of this source code is governed by a BSD-style license that can be// found in the LICENSE file.(function() {'use strict';/** * T-Rex runner. * @param {string} outerContainerId Outer containing element id. * @param {Object} opt_config * @constructor * @export */function Runner(outerContainerId, opt_config) { // Singleton if (Runner.instance_) { return Runner.instance_; } Runner.instance_ = this; this.outerContainerEl = document.querySelector(outerContainerId); this.containerEl = null; this.snackbarEl = null; this.config = opt_config || Runner.config; // Logical dimensions of the container. this.dimensions = Runner.defaultDimensions; this.canvas = null; this.canvasCtx = null; this.tRex = null; this.distanceMeter = null; this.distanceRan = 0; this.highestScore = 0; this.time = 0; this.runningTime = 0; this.msPerFrame = 1000 / FPS; this.currentSpeed = this.config.SPEED; this.obstacles = []; this.activated = false; // Whether the easter egg has been activated. this.playing = false; // Whether the game is currently in play state. this.crashed = false; this.paused = false; this.inverted = false; this.invertTimer = 0; this.resizeTimerId_ = null; this.bdayFlashTimer = null; this.playCount = 0; // Sound FX. this.audioBuffer = null; this.soundFx = {}; // Global web audio context for playing sounds. this.audioContext = null; // Images. this.images = {}; this.imagesLoaded = 0; if (this.isDisabled()) { this.setupDisabledRunner(); } else { this.loadImages(); }}window['Runner'] = Runner;/** * Default game width. * @const */var DEFAULT_WIDTH = 600;/** * Frames per second. * @const */var FPS = 60;/** @const */var IS_HIDPI = window.devicePixelRatio > 1;/** @const */var IS_IOS = /iPad|iPhone|iPod/.test(window.navigator.platform);/** @const */var IS_MOBILE = /Android/.test(window.navigator.userAgent) || IS_IOS;/** @const */var ARCADE_MODE_URL = 'chrome://dino/';/** * Default game configuration. * @enum {number} */Runner.config = { ACCELERATION: 0.001, BG_CLOUD_SPEED: 0.2, BOTTOM_PAD: 10, BOTTOM_PAD_BDAY: 26, BDAY_FLASH_DURATION: 1000, BDAY_Y_POS_ADJUST: 16, CLEAR_TIME: 3000, CLOUD_FREQUENCY: 0.5, GAMEOVER_CLEAR_TIME: 750, GAP_COEFFICIENT: 0.6, GRAVITY: 0.6, INITIAL_JUMP_VELOCITY: 12, INVERT_FADE_DURATION: 12000, INVERT_DISTANCE: 700, MAX_BLINK_COUNT: 3, MAX_CLOUDS: 6, MAX_OBSTACLE_LENGTH: 3, MAX_OBSTACLE_DUPLICATION: 2, MAX_SPEED: 13, MIN_JUMP_HEIGHT: 35, MOBILE_SPEED_COEFFICIENT: 1.2, RESOURCE_TEMPLATE_ID: 'audio-resources', SPEED: 6, SPEED_DROP_COEFFICIENT: 3, ARCADE_MODE_INITIAL_TOP_POSITION: 35, ARCADE_MODE_TOP_POSITION_PERCENT: 0.1};/** * Default dimensions. * @enum {string} */Runner.defaultDimensions = { WIDTH: DEFAULT_WIDTH, HEIGHT: 150};/** * CSS class names. * @enum {string} */Runner.classes = { ARCADE_MODE: 'arcade-mode', CANVAS: 'runner-canvas', CONTAINER: 'runner-container', CRASHED: 'crashed', ICON: 'icon-offline', INVERTED: 'inverted', SNACKBAR: 'snackbar', SNACKBAR_SHOW: 'snackbar-show', TOUCH_CONTROLLER: 'controller'};/** * Sprite definition layout of the spritesheet. * @enum {Object} */Runner.spriteDefinition = { LDPI: { BALLOON: {x: 417, y: 29}, CACTUS_LARGE: {x: 332, y: 2}, CACTUS_SMALL: {x: 228, y: 2}, CLOUD: {x: 86, y: 2}, HORIZON: {x: 2, y: 54}, MOON: {x: 484, y: 2}, PTERODACTYL: {x: 134, y: 2}, RESTART: {x: 2, y: 2}, TEXT_SPRITE: {x: 655, y: 2}, TREX: {x: 848, y: 2}, TREX_BDAY: {x: 0, y: 0}, SNACK: {x: 384, y: 22}, STAR: {x: 645, y: 2} }, HDPI: { BALLOON: {x: 834, y: 58}, CACTUS_LARGE: {x: 652, y: 2}, CACTUS_SMALL: {x: 446, y: 2}, CLOUD: {x: 166, y: 2}, HORIZON: {x: 2, y: 104}, MOON: {x: 954, y: 2}, PTERODACTYL: {x: 260, y: 2}, RESTART: {x: 2, y: 2}, TEXT_SPRITE: {x: 1294, y: 2}, TREX: {x: 1678, y: 2}, TREX_BDAY: {x: 0, y: 0}, SNACK: {x: 768, y: 44}, STAR: {x: 1276, y: 2} }};/** * Sound FX. Reference to the ID of the audio tag on interstitial page. * @enum {string} */Runner.sounds = { BUTTON_PRESS: 'offline-sound-press', HIT: 'offline-sound-hit', SCORE: 'offline-sound-reached'};/** * Key code mapping. * @enum {Object} */Runner.keycodes = { JUMP: {'38': 1, '32': 1}, // Up, spacebar DUCK: {'40': 1}, // Down RESTART: {'13': 1} // Enter};/** * Runner event names. * @enum {string} */Runner.events = { ANIM_END: 'webkitAnimationEnd', CLICK: 'click', KEYDOWN: 'keydown', KEYUP: 'keyup', POINTERDOWN: 'pointerdown', POINTERUP: 'pointerup', RESIZE: 'resize', TOUCHEND: 'touchend', TOUCHSTART: 'touchstart', VISIBILITY: 'visibilitychange', BLUR: 'blur', FOCUS: 'focus', LOAD: 'load'};Runner.prototype = { /** * Whether the easter egg has been disabled. CrOS enterprise enrolled devices. * @return {boolean} */ isDisabled: function() { return loadTimeData && loadTimeData.valueExists('disabledEasterEgg'); }, /** * For disabled instances, set up a snackbar with the disabled message. */ setupDisabledRunner: function() { this.containerEl = document.createElement('div'); this.containerEl.className = Runner.classes.SNACKBAR; this.containerEl.textContent = loadTimeData.getValue('disabledEasterEgg'); this.outerContainerEl.appendChild(this.containerEl); // Show notification when the activation key is pressed. document.addEventListener(Runner.events.KEYDOWN, function(e) { if (Runner.keycodes.JUMP[e.keyCode]) { this.containerEl.classList.add(Runner.classes.SNACKBAR_SHOW); document.querySelector('.icon').classList.add('icon-disabled'); } }.bind(this)); }, /** * Setting individual settings for debugging. * @param {string} setting * @param {*} value */ updateConfigSetting: function(setting, value) { if (setting in this.config && value != undefined) { this.config[setting] = value; switch (setting) { case 'GRAVITY': case 'MIN_JUMP_HEIGHT': case 'SPEED_DROP_COEFFICIENT': this.tRex.config[setting] = value; break; case 'INITIAL_JUMP_VELOCITY': this.tRex.setJumpVelocity(value); break; case 'SPEED': this.setSpeed(value); break; } } }, /** * Cache the appropriate image sprite from the page and get the sprite sheet * definition. */ loadImages: function() { if (IS_HIDPI) { Runner.imageSprite = document.getElementById('offline-resources-2x'); Runner.bdayImageSprite = document.getElementById('offline-resources-bday-2x'); this.spriteDef = Runner.spriteDefinition.HDPI; } else { Runner.imageSprite = document.getElementById('offline-resources-1x'); Runner.bdayImageSprite = document.getElementById('offline-resources-bday-1x'); this.spriteDef = Runner.spriteDefinition.LDPI; } if (Runner.imageSprite.complete) { this.init(); } else { // If the images are not yet loaded, add a listener. Runner.imageSprite.addEventListener(Runner.events.LOAD, this.init.bind(this)); } }, /** * Load and decode base 64 encoded sounds. */ loadSounds: function() { if (!IS_IOS) { this.audioContext = new AudioContext(); var resourceTemplate = document.getElementById(this.config.RESOURCE_TEMPLATE_ID).content; for (var sound in Runner.sounds) { var soundSrc = resourceTemplate.getElementById(Runner.sounds[sound]).src; soundSrc = soundSrc.substr(soundSrc.indexOf(',') + 1); var buffer = decodeBase64ToArrayBuffer(soundSrc); // Async, so no guarantee of order in array. this.audioContext.decodeAudioData(buffer, function(index, audioData) { this.soundFx[index] = audioData; }.bind(this, sound)); } } }, /** * Sets the game speed. Adjust the speed accordingly if on a smaller screen. * @param {number} opt_speed */ setSpeed: function(opt_speed) { var speed = opt_speed || this.currentSpeed; // Reduce the speed on smaller mobile screens. if (this.dimensions.WIDTH < DEFAULT_WIDTH) { var mobileSpeed = speed * this.dimensions.WIDTH / DEFAULT_WIDTH * this.config.MOBILE_SPEED_COEFFICIENT; this.currentSpeed = mobileSpeed > speed ? speed : mobileSpeed; } else if (opt_speed) { this.currentSpeed = opt_speed; } }, /** * Game initialiser. */ init: function() { // Hide the static icon. document.querySelector('.' + Runner.classes.ICON).style.visibility = 'hidden'; this.adjustDimensions(); this.setSpeed(); this.containerEl = document.createElement('div'); this.containerEl.className = Runner.classes.CONTAINER; // Player canvas container. this.canvas = createCanvas(this.containerEl, this.dimensions.WIDTH, this.dimensions.HEIGHT, Runner.classes.PLAYER); this.canvasCtx = this.canvas.getContext('2d'); this.canvasCtx.fillStyle = '#f7f7f7'; this.canvasCtx.fill(); Runner.updateCanvasScaling(this.canvas); // Horizon contains clouds, obstacles and the ground. this.horizon = new Horizon(this.canvas, this.spriteDef, this.dimensions, this.config.GAP_COEFFICIENT); // Distance meter this.distanceMeter = new DistanceMeter(this.canvas, this.spriteDef.TEXT_SPRITE, this.dimensions.WIDTH); // Draw t-rex this.tRex = new Trex(this.canvas, this.spriteDef.TREX); this.outerContainerEl.appendChild(this.containerEl); this.startListening(); this.update(); window.addEventListener(Runner.events.RESIZE, this.debounceResize.bind(this)); }, /** * Create the touch controller. A div that covers whole screen. */ createTouchController: function() { this.touchController = document.createElement('div'); this.touchController.className = Runner.classes.TOUCH_CONTROLLER; this.touchController.addEventListener(Runner.events.TOUCHSTART, this); this.touchController.addEventListener(Runner.events.TOUCHEND, this); }, /** * Debounce the resize event. */ debounceResize: function() { if (!this.resizeTimerId_) { this.resizeTimerId_ = setInterval(this.adjustDimensions.bind(this), 250); } }, /** * Adjust game space dimensions on resize. */ adjustDimensions: function() { clearInterval(this.resizeTimerId_); this.resizeTimerId_ = null; var boxStyles = window.getComputedStyle(this.outerContainerEl); var padding = Number(boxStyles.paddingLeft.substr(0, boxStyles.paddingLeft.length - 2)); this.dimensions.WIDTH = this.outerContainerEl.offsetWidth - padding * 2; if (this.isArcadeMode()) { this.dimensions.WIDTH = Math.min(DEFAULT_WIDTH, this.dimensions.WIDTH); if (this.activated) { this.setArcadeModeContainerScale(); } } // Redraw the elements back onto the canvas. if (this.canvas) { this.canvas.width = this.dimensions.WIDTH; this.canvas.height = this.dimensions.HEIGHT; Runner.updateCanvasScaling(this.canvas); this.distanceMeter.calcXPos(this.dimensions.WIDTH); this.clearCanvas(); this.horizon.update(0, 0, true); this.tRex.update(0); // Outer container and distance meter. if (this.playing || this.crashed || this.paused) { this.containerEl.style.width = this.dimensions.WIDTH + 'px'; this.containerEl.style.height = this.dimensions.HEIGHT + 'px'; this.distanceMeter.update(0, Math.ceil(this.distanceRan)); this.stop(); } else { this.tRex.draw(0, 0); } // Game over panel. if (this.crashed && this.gameOverPanel) { this.gameOverPanel.updateDimensions(this.dimensions.WIDTH); this.gameOverPanel.draw(); } } }, /** * Play the game intro. * Canvas container width expands out to the full width. */ playIntro: function() { if (!this.activated && !this.crashed) { this.playingIntro = true; this.tRex.playingIntro = true; // CSS animation definition. var keyframes = '@-webkit-keyframes intro { ' + 'from { width:' + Trex.config.WIDTH + 'px }' + 'to { width: ' + this.dimensions.WIDTH + 'px }' + '}'; document.styleSheets[0].insertRule(keyframes, 0); this.containerEl.addEventListener(Runner.events.ANIM_END, this.startGame.bind(this)); this.containerEl.style.webkitAnimation = 'intro .4s ease-out 1 both'; this.containerEl.style.width = this.dimensions.WIDTH + 'px'; if (this.touchController) { this.outerContainerEl.appendChild(this.touchController); } this.playing = true; this.activated = true; } else if (this.crashed) { this.restart(); } }, /** * Update the game status to started. */ startGame: function() { if (this.isArcadeMode()) { this.setArcadeMode(); } this.runningTime = 0; this.playingIntro = false; this.tRex.playingIntro = false; this.containerEl.style.webkitAnimation = ''; this.playCount++; // Handle tabbing off the page. Pause the current game. document.addEventListener(Runner.events.VISIBILITY, this.onVisibilityChange.bind(this)); window.addEventListener(Runner.events.BLUR, this.onVisibilityChange.bind(this)); window.addEventListener(Runner.events.FOCUS, this.onVisibilityChange.bind(this)); }, clearCanvas: function() { this.canvasCtx.clearRect(0, 0, this.dimensions.WIDTH, this.dimensions.HEIGHT); }, /** * Update the game frame and schedules the next one. */ update: function() { this.updatePending = false; var now = getTimeStamp(); var deltaTime = now - (this.time || now); // Flashing. if (this.bdayFlashTimer != null) { if (this.bdayFlashTimer <= 0) { this.bdayFlashTimer = null; this.tRex.setFlashing(false); this.tRex.enableBdayMode(this.spriteDef.TREX_BDAY); } else { this.bdayFlashTimer -= deltaTime; this.tRex.update(deltaTime); deltaTime = 0; } } this.time = now; if (this.playing) { this.clearCanvas(); if (this.tRex.jumping) { this.tRex.updateJump(deltaTime); } this.runningTime += deltaTime; var hasObstacles = this.runningTime > this.config.CLEAR_TIME; // First jump triggers the intro. if (this.tRex.jumpCount == 1 && !this.playingIntro) { this.playIntro(); } // The horizon doesn't move until the intro is over. if (this.playingIntro) { this.horizon.update(0, this.currentSpeed, hasObstacles); } else { deltaTime = !this.activated ? 0 : deltaTime; this.horizon.update(deltaTime, this.currentSpeed, hasObstacles, this.inverted); } // Check for collisions. var collision = hasObstacles && checkForCollision(this.horizon.obstacles[0], this.tRex); // Ate snack. if (Runner.isBdayModeEnabled() && collision && this.horizon.obstacles[0].typeConfig.type == 'SNACK') { this.horizon.enableBdayMode(); this.tRex.setFlashing(true); collision = false; this.bdayFlashTimer = this.config.BDAY_FLASH_DURATION; } if (!collision) { this.distanceRan += this.currentSpeed * deltaTime / this.msPerFrame; if (this.currentSpeed < this.config.MAX_SPEED) { this.currentSpeed += this.config.ACCELERATION; } } else { this.gameOver(); } var playAchievementSound = this.distanceMeter.update(deltaTime, Math.ceil(this.distanceRan)); if (playAchievementSound) { this.playSound(this.soundFx.SCORE); } // Night mode. if (this.invertTimer > this.config.INVERT_FADE_DURATION) { this.invertTimer = 0; this.invertTrigger = false; this.invert(); } else if (this.invertTimer) { this.invertTimer += deltaTime; } else { var actualDistance = this.distanceMeter.getActualDistance(Math.ceil(this.distanceRan)); if (actualDistance > 0) { this.invertTrigger = !(actualDistance % this.config.INVERT_DISTANCE); if (this.invertTrigger && this.invertTimer === 0) { this.invertTimer += deltaTime; this.invert(); } } } } if (this.playing || (!this.activated && this.tRex.blinkCount < Runner.config.MAX_BLINK_COUNT)) { this.tRex.update(deltaTime); this.scheduleNextUpdate(); } }, /** * Event handler. */ handleEvent: function(e) { return (function(evtType, events) { switch (evtType) { case events.KEYDOWN: case events.TOUCHSTART: case events.POINTERDOWN: this.onKeyDown(e); break; case events.KEYUP: case events.TOUCHEND: case events.POINTERUP: this.onKeyUp(e); break; } }.bind(this))(e.type, Runner.events); }, /** * Bind relevant key / mouse / touch listeners. */ startListening: function() { // Keys. document.addEventListener(Runner.events.KEYDOWN, this); document.addEventListener(Runner.events.KEYUP, this); // Touch / pointer. this.containerEl.addEventListener(Runner.events.TOUCHSTART, this); document.addEventListener(Runner.events.POINTERDOWN, this); document.addEventListener(Runner.events.POINTERUP, this); }, /** * Remove all listeners. */ stopListening: function() { document.removeEventListener(Runner.events.KEYDOWN, this); document.removeEventListener(Runner.events.KEYUP, this); if (this.touchController) { this.touchController.removeEventListener(Runner.events.TOUCHSTART, this); this.touchController.removeEventListener(Runner.events.TOUCHEND, this); } this.containerEl.removeEventListener(Runner.events.TOUCHSTART, this); document.removeEventListener(Runner.events.POINTERDOWN, this); document.removeEventListener(Runner.events.POINTERUP, this); }, /** * Process keydown. * @param {Event} e */ onKeyDown: function(e) { // Prevent native page scrolling whilst tapping on mobile. if (IS_MOBILE && this.playing) { e.preventDefault(); } if (!this.crashed && !this.paused) { if (Runner.keycodes.JUMP[e.keyCode] || e.type == Runner.events.TOUCHSTART) { e.preventDefault(); // Starting the game for the first time. if (!this.playing) { // Started by touch so create a touch controller. if (!this.touchController && e.type == Runner.events.TOUCHSTART) { this.createTouchController(); } this.loadSounds(); this.playing = true; this.update(); if (window.errorPageController) { errorPageController.trackEasterEgg(); } } // Start jump. if (!this.tRex.jumping && !this.tRex.ducking) { this.playSound(this.soundFx.BUTTON_PRESS); this.tRex.startJump(this.currentSpeed); } } else if (this.playing && Runner.keycodes.DUCK[e.keyCode]) { e.preventDefault(); if (this.tRex.jumping) { // Speed drop, activated only when jump key is not pressed. this.tRex.setSpeedDrop(); } else if (!this.tRex.jumping && !this.tRex.ducking) { // Duck. this.tRex.setDuck(true); } } } else if (this.crashed && e.type == Runner.events.TOUCHSTART && e.currentTarget == this.containerEl) { this.restart(); } }, /** * Process key up. * @param {Event} e */ onKeyUp: function(e) { var keyCode = String(e.keyCode); var isjumpKey = Runner.keycodes.JUMP[keyCode] || e.type == Runner.events.TOUCHEND || e.type == Runner.events.POINTERUP; if (this.isRunning() && isjumpKey) { this.tRex.endJump(); } else if (Runner.keycodes.DUCK[keyCode]) { this.tRex.speedDrop = false; this.tRex.setDuck(false); } else if (this.crashed) { // Check that enough time has elapsed before allowing jump key to restart. var deltaTime = getTimeStamp() - this.time; if (Runner.keycodes.RESTART[keyCode] || this.isLeftClickOnCanvas(e) || (deltaTime >= this.config.GAMEOVER_CLEAR_TIME && Runner.keycodes.JUMP[keyCode])) { this.restart(); } } else if (this.paused && isjumpKey) { // Reset the jump state this.tRex.reset(); this.play(); } }, /** * Returns whether the event was a left click on canvas. * On Windows right click is registered as a click. * @param {Event} e * @return {boolean} */ isLeftClickOnCanvas: function(e) { return e.button != null && e.button < 2 && e.type == Runner.events.POINTERUP && e.target == this.canvas; }, /** * RequestAnimationFrame wrapper. */ scheduleNextUpdate: function() { if (!this.updatePending) { this.updatePending = true; this.raqId = requestAnimationFrame(this.update.bind(this)); } }, /** * Whether the game is running. * @return {boolean} */ isRunning: function() { return !!this.raqId; }, /** * Game over state. */ gameOver: function() { this.playSound(this.soundFx.HIT); vibrate(200); this.stop(); this.crashed = true; this.distanceMeter.achievement = false; this.tRex.update(100, Trex.status.CRASHED); // Game over panel. if (!this.gameOverPanel) { this.gameOverPanel = new GameOverPanel(this.canvas, this.spriteDef.TEXT_SPRITE, this.spriteDef.RESTART, this.dimensions); } else { this.gameOverPanel.draw(); } // Update the high score. if (this.distanceRan > this.highestScore) { this.highestScore = Math.ceil(this.distanceRan); this.distanceMeter.setHighScore(this.highestScore); } // Reset the time clock. this.time = getTimeStamp(); }, stop: function() { this.playing = false; this.paused = true; cancelAnimationFrame(this.raqId); this.raqId = 0; }, play: function() { if (!this.crashed) { this.playing = true; this.paused = false; this.tRex.update(0, Trex.status.RUNNING); this.time = getTimeStamp(); this.update(); } }, restart: function() { if (!this.raqId) { this.playCount++; this.runningTime = 0; this.playing = true; this.paused = false; this.crashed = false; this.distanceRan = 0; this.setSpeed(this.config.SPEED); this.time = getTimeStamp(); this.containerEl.classList.remove(Runner.classes.CRASHED); this.clearCanvas(); this.distanceMeter.reset(this.highestScore); this.horizon.reset(); this.tRex.reset(); this.playSound(this.soundFx.BUTTON_PRESS); this.invert(true); this.bdayFlashTimer = null; this.update(); } }, /** * Whether the game should go into arcade mode. * @return {boolean} */ isArcadeMode: function() { return document.title == ARCADE_MODE_URL; }, /** * Hides offline messaging for a fullscreen game only experience. */ setArcadeMode: function() { document.body.classList.add(Runner.classes.ARCADE_MODE); this.setArcadeModeContainerScale(); }, /** * Sets the scaling for arcade mode. */ setArcadeModeContainerScale: function() { var windowHeight = window.innerHeight; var scaleHeight = windowHeight / this.dimensions.HEIGHT; var scaleWidth = window.innerWidth / this.dimensions.WIDTH; var scale = Math.max(1, Math.min(scaleHeight, scaleWidth)); var scaledCanvasHeight = this.dimensions.HEIGHT * scale; // Positions the game container at 10% of the available vertical window // height minus the game container height. var translateY = Math.ceil(Math.max(0, (windowHeight - scaledCanvasHeight - Runner.config.ARCADE_MODE_INITIAL_TOP_POSITION) * Runner.config.ARCADE_MODE_TOP_POSITION_PERCENT)) * window.devicePixelRatio; this.containerEl.style.transform = 'scale(' + scale + ') translateY(' + translateY + 'px)'; }


[未上市股票投資達人] 本週未上市股票推薦比賽<未上市達人>出爐: 第一名 無相 未上市股票:康全電訊 漲幅: 85.33% , 第二名 家棟 未上市股票:寶德能源 漲幅: 82.11% , 第三名 Ray chen 未上市股票:力智電子 漲幅: 80.20% , 第四名 陳 未上市股票:太電 漲幅: 71.43% , 第五名 更 未上市股票:力晶科技 漲幅: 65.83% ,