Compare commits

..

No commits in common. "d719a3af9a2cdd4ecd5ad655d4f21f5244ee3ff9" and "b856cb894f734d92b275e8caba5c56b45d54656c" have entirely different histories.

25 changed files with 7805 additions and 6913 deletions

View file

@ -1,8 +0,0 @@
root = true
[*]
end_of_line = lf
insert_final_newline = true
indent_style = space
indent_size = 4
charset = utf-8

40
css/colours.css Normal file
View file

@ -0,0 +1,40 @@
/* -------------------------------------------------------------------
* Colours for the CumulusMX Alternative Interface
* Produced using w3Schools colour generator
*
* Key Colour: #4e5b31
*
* Theme modified to change font 'color's to either lightest or darkest
* theme colour. Also modified names for text, borders & hover colours.
* I have added a few extras. Not all are used.
* Neil Thomas
------------------------------------------------------------------*/
/* Check that your theme is named as shown below */
.w3-theme-white {color:#2e5473; background-color:#FFFFFF;}
.w3-theme-l5 {color:#2e5473; background-color:#f7fafc;}
.w3-theme-l4 {color:#2e5473; background-color:#e4edf4;}
.w3-theme-l3 {color:#2e5473 ; background-color:#c9dbe9;}
.w3-theme-l2 {color:#2e5473 ; background-color:#aec9df;}
.w3-theme-l1 {color:#2e5473 ; background-color:#93b7d4;}
.w3-theme-d1 {color:#f7fafc ; background-color:#6195c0;}
.w3-theme-d2 {color:#f7fafc ; background-color:#4a86b7;}
.w3-theme-d3 {color:#f7fafc ; background-color:#4075a1;}
.w3-theme-d4 {color:#f7fafc ; background-color:#37658a;}
.w3-theme-d5 {color:#f7fafc ; background-color:#2e5473;}
.w3-theme-light {color:#2e5473 ; background-color:#f7fafc;}
.w3-theme-dark {color:#f7fafc ; background-color:#2e5473;}
.w3-theme-action {color:#f7fafc ; background-color:#2e5473;}
.w3-theme {color:#f7fafc ; background-color:#78a5c9;}
.w3-theme-txt {color:#78a5c9;}
.w3-theme-bdr {border-color:#78a5c9;}
.w3-theme-d5-bdr {border-color:#2e5473;}
.w3-theme-l1-bdr {border-color:#f7fafc;}
.w3-theme-hvr:hover {color:#f7fafc; background-color:#78a5c9;}
.w3-theme-d5-hvr:hover {color:#f7fafc; background-color:#2e5473;}
.w3-theme-txt-hvr:hover {color:#78a5c9;}
.w3-theme-bdr-hvr:hover {border-color:#78a5c9;}

File diff suppressed because one or more lines are too long

249
css/mx-templates.css Normal file
View file

@ -0,0 +1,249 @@
/* -----------------------------------
* Styles for CumulusMX Templates
Last modified: 2021/03/19 09:23:15
* ----------------------------------*/
html,
body,
p,
h1,
h2,
h3,
h4,
h5,
h6,
li,
td,
th {
font-family: "Rosario", sans-serif;
}
p {
font-size: 15px;
}
#Header {
border-style: solid;
border-width: 0 0 10px 0;
}
.site-width {
max-width: 1140px;
margin: auto;
}
.graph-width {
max-width: 1250px;
margin: auto;
}
#Footer {
border-width: 5px 0 0 0;
border-style: solid;
}
.logo {
max-width: 250px;
margin: 5px 0 5px 16px;
}
.subText {
font-size: 80% !important;
font-weight: 400;
}
body {
background-image: url("../images/picture.jpg");
background-position: bottom left;
background-repeat: no-repeat;
background-attachment: fixed;
}
.statusPanel h5 {
margin-bottom: -5px;
}
/* -------------------------------------
* Flex boxes
* -------------------------------------*/
.at-flex-start {
display: flex;
}
.at-flex-end {
display: flex;
justify-content: flex-end;
flex-wrap: wrap;
}
.at-flex-justify {
display: flex;
justify-content: space-around;
flex-wrap: wrap;
}
.at-flex-between {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}
.at-flex-bottom,
.at-flex-items-bottom {
align-items: flex-end;
}
.at-flex-items-center {
align-items: center;
}
/* --------------------------------------------------
* Menu enhancements
* --------------------------------------------------*/
#Main_Menu {
margin-bottom: 4px;
border-width: 2px 0 0 0;
border-style: solid;
min-height: 32px;
}
.at-slim {
padding: 4px 14px !important;
}
.at-divider {
margin: 0 5px;
color: #f80;
}
.at-spacer {
min-height: 2em;
}
.at-menu-lable {
display: block;
width: 100%;
font-size: 13px;
font-style: italic;
padding-bottom: 2px !important;
padding-top: 4px !important;
border-bottom: 1px dotted #c2cfa5 !important;
}
.at-menu-bar {
display: block;
height: 2px;
padding: 0 2px !important;
}
.at-indent {
padding-left: 40px !important;
}
/* -------------------------------
* Model enhancements
* ------------------------------*/
.w3-modal-content {
margin-top: 10%;
border-radius: 8px;
}
.w3-modal header {
border-radius: 8px 8px 0 0;
}
.w3-modal footer {
border-radius: 0 0 8px 8px;
}
.w3-modal .w3-btn {
border-radius: 0 8px;
}
/* ----------------------------------------
* Media enhancements
* ---------------------------------------*/
@media screen and (max-width: 780px) {
#Footer {
position: unset;
}
#Content {
/*margin-top: 170px!important;*/
margin-bottom: 5px !important;
}
.statusPanel {
text-align: center !important;
margin: auto !important;
}
}
@media screen and (max-height: 768px) {
#Footer {
position: unset;
item: center;
}
#Content {
margin-bottom: 5px !important;
}
}
/* --------------------------------------
* LED enhancements
* -------------------------------------*/
.at-led-round {
display: inline-block;
height: 1.2em;
width: 1.2em;
margin: 0 0.5em -3px 0.5em;
border-radius: 50%;
background-color: #888;
box-shadow: inset 3px 3px 2px rgba(220, 220, 220, 0.6),
inset -2px -2px 2px rgba(32, 32, 32, 0.6);
}
.at-led-block {
display: inline-block;
height: 1.2em;
width: 1.2em;
margin: 0 0.5em -3px 0.5em;
background-color: #888;
box-shadow: inset 3px 3px 2px rgba(220, 220, 220, 0.6),
inset -2px -2px 2px rgba(32, 32, 32, 0.6);
}
.at-led-brick {
display: inline-block;
height: 0.8em;
width: 1.6em;
margin: 0 0.5em -3px 0.5em;
background-color: #888;
box-shadow: inset 3px 3px 2px rgba(220, 220, 220, 0.6),
inset -2px -2px 2px rgba(32, 32, 32, 0.6);
}
.at-led-oval {
display: inline-block;
height: 1em;
width: 2em;
margin: 0 0.5em -3px 0.5em;
border-radius: 50%;
background-color: #888;
box-shadow: inset 3px 3px 2px rgba(220, 220, 220, 0.6),
inset -2px -2px 2px rgba(32, 32, 32, 0.6);
}
.at-led-green {
background-color: #0b0;
}
.at-led-flash-red {
animation: flashR 1s infinite;
}
@keyframes flashR {
0%,
60% {
background-color: #f00;
}
61%,
100% {
background-color: #800;
}
}

247
css/w3Pro.css Normal file
View file

@ -0,0 +1,247 @@
/* W3PRO.CSS 4.15 December 2020 by Jan Egil and Borge Refsnes */
html {
box-sizing: border-box;
}
*,
*:before,
*:after {
box-sizing: inherit;
}
/* Extract from normalize.css by Nicolas Gallagher and Jonathan Neal git.io/normalize */
html {
-ms-text-size-adjust: 100%;
-webkit-text-size-adjust: 100%;
}
body {
margin: 0;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section {
display: block;
}
summary {
display: list-item;
}
audio,
canvas,
progress,
video {
display: inline-block;
}
progress {
vertical-align: baseline;
}
audio:not([controls]) {
display: none;
height: 0;
}
[hidden],
template {
display: none;
}
a {
background-color: transparent;
}
a:active,
a:hover {
outline-width: 0;
}
abbr[title] {
border-bottom: none;
text-decoration: underline;
text-decoration: underline dotted;
}
b,
strong {
font-weight: bolder;
}
dfn {
font-style: italic;
}
mark {
background: #ff0;
color: #000;
}
small {
font-size: 80%;
}
sub,
sup {
font-size: 75%;
line-height: 0;
position: relative;
vertical-align: baseline;
}
sub {
bottom: -0.25em;
}
sup {
top: -0.5em;
}
figure {
margin: 1em 40px;
}
img {
border-style: none;
}
code,
kbd,
pre,
samp {
font-family: monospace, monospace;
font-size: 1em;
}
hr {
box-sizing: content-box;
height: 0;
overflow: visible;
}
button,
input,
select,
textarea,
optgroup {
font: inherit;
margin: 0;
}
optgroup {
font-weight: bold;
}
button,
input {
overflow: visible;
}
button,
select {
text-transform: none;
}
button,
[type="button"],
[type="reset"],
[type="submit"] {
-webkit-appearance: button;
}
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
border-style: none;
padding: 0;
}
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
outline: 1px dotted ButtonText;
}
fieldset {
border: 1px solid #c0c0c0;
margin: 0 2px;
padding: 0.35em 0.625em 0.75em;
}
legend {
color: inherit;
display: table;
max-width: 100%;
padding: 0;
white-space: normal;
}
textarea {
overflow: auto;
}
[type="checkbox"],
[type="radio"] {
padding: 0;
}
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
height: auto;
}
[type="search"] {
-webkit-appearance: textfield;
outline-offset: -2px;
}
[type="search"]::-webkit-search-decoration {
-webkit-appearance: none;
}
::-webkit-file-upload-button {
-webkit-appearance: button;
font: inherit;
}
/* End extract */
html,
body {
font-family: Verdana, sans-serif;
font-size: 15px;
line-height: 1.5;
}
html {
overflow-x: hidden;
}
h1 {
font-size: 36px;
}
h2 {
font-size: 30px;
}
h3 {
font-size: 24px;
}
h4 {
font-size: 20px;
}
h5 {
font-size: 18px;
}
h6 {
font-size: 16px;
}
.w3-serif {
font-family: serif;
}
.w3-sans-serif {
font-family: sans-serif;
}
.w3-cursive {
font-family: cursive;
}
.w3-monospace {
font-family: monospace;
}
h1,
h2,
h3,
h4,
h5,
h6 {
font-family: "Segoe UI", Arial, sans-serif;
font-weight: 400;
margin: 10px 0;
}
.w3-wide {
letter-spacing: 4px;
}
hr {
border: 0;
border-top: 1px solid #eee;
margin: 20px 0;
}
.w3-image {
max-width: 100%;
height: auto;
}
img {
vertical-align: middle;
}
a {
color: inherit;
}

View file

@ -94,20 +94,6 @@ div.page-container > div:last-child {
margin-bottom: 0; margin-bottom: 0;
} }
div#header {
display: grid;
grid-template-columns: 66px 1fr;
grid-template-rows: 1fr;
grid-column-gap: 15px;
grid-row-gap: 0px;
}
div#header img {
filter: drop-shadow(2px 2px hsl(0, 0%, 66%));
margin-right: 10px;
image-rendering: pixelated;
}
div#header h1 { div#header h1 {
margin: 0; margin: 0;
font-style: italic; font-style: italic;
@ -132,8 +118,8 @@ div#footer {
display: grid; display: grid;
grid-template-columns: auto 1fr; grid-template-columns: auto 1fr;
grid-template-rows: 1fr; grid-template-rows: 1fr;
grid-column-gap: 0; grid-column-gap: 0px;
grid-row-gap: 0; grid-row-gap: 0px;
align-items: center; align-items: center;
} }
@ -141,6 +127,14 @@ div#footer div:last-child {
text-align: right; text-align: right;
} }
div#footer div:last-child img {
image-rendering: pixelated;
margin: 0;
padding: 0;
width: 88px;
height: 31px;
}
/* -------------------------------------------------------------------------- */ /* -------------------------------------------------------------------------- */
table.almanac td:nth-child(odd) { table.almanac td:nth-child(odd) {
@ -159,33 +153,32 @@ table.almanac {
min-width: 100%; min-width: 100%;
} }
table.mx-datatable { table.conditions-now {
width: 100%;
border-collapse: collapse; border-collapse: collapse;
border: var(--border); border: var(--border);
filter: var(--shadow-small); filter: var(--shadow-small);
background-color: var(--background); background-color: var(--background);
} }
table.mx-datatable th { table.conditions-now th {
text-align: left; text-align: left;
background-color: var(--background-dim); background-color: var(--background-dim);
border-top: var(--border); border-top: var(--border);
} }
table.mx-datatable tr td, table.conditions-now tr td,
table.mx-datatable tr th { table.conditions-now tr th {
padding: 5px 10px 5px 5px; padding: 5px 10px 5px 5px;
} }
table.mx-datatable tr td:nth-child(2) { table.conditions-now tr td:nth-child(2) {
padding-right: 40px; padding-right: 40px;
} }
table.current-conditions tr td:nth-child(odd) { table.conditions-now tr td:nth-child(odd) {
font-weight: bold; font-weight: bold;
} }
table.current-conditions tr:last-child td:nth-child(3) { table.conditions-now tr:last-child td:nth-child(3) {
font-weight: normal; font-weight: normal;
font-style: italic; font-style: italic;
} }

BIN
images/CumulusMX-Logo.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 22 KiB

BIN
images/favicon.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 57 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 22 KiB

BIN
images/picture.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 KiB

View file

@ -1,12 +0,0 @@
<div id="footer">
<div>
<span>
&copy; floppydisk 2021-<?= date("Y") ?>
</span>
</div>
<div>
<span>
Powered by Cumulus MX v:<span data-cmxdata="version"></span>, b:<span data-cmxdata="build"></span>
</span>
</div>
</div>

View file

@ -1,14 +0,0 @@
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="description" content="weather data">
<meta name="keywords" content="Cumulus, weather, data, weather station">
<title>Cumulus MX</title>
<link rel="icon" type="image/png" href="/images/favicon.png">
<script src="/lib/jquery/jquery-latest.min.js"></script>
<!-- All Styles -->
<link href="/css/wah.css" rel="stylesheet"> <!-- Specific styles for these templates. -->
<!-- Scripts -->
<script src="/js/setpagedata.js"></script> <!-- Utility javascripts for all pages. -->

View file

@ -1,19 +0,0 @@
<div id="header">
<div>
<img src="/images/logo.png" width="65">
</div>
<div>
<h1>wah's the weather?</h1>
<nav>
<strong>Pages:</strong>
<a href="/">now</a> |
<a href="/today">today</a> |
<a href="/yesterday">yesterday</a> |
<a href="/todayyest">today-yest</a> |
<a href="/gauges">gauges</a> |
<a href="/records">records</a> |
<a href="/charts">charts</a> |
<a href="/reports">reports</a>
</nav>
</div>
</div>

View file

@ -2,13 +2,26 @@
<html lang="en"> <html lang="en">
<head> <head>
<?php include("./includes/head.inc.php"); ?> <meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="description" content="weather data">
<meta name="keywords" content="Cumulus, weather, data, weather station">
<title>Cumulus MX</title>
<link rel="icon" type="image/png" href="images/favicon.png">
<script src="lib/jquery/jquery-latest.min.js"></script>
<!-- All Styles -->
<link href="css/wah.css" rel="stylesheet"> <!-- Specific styles for these templates. -->
<!-- Scripts -->
<script src="js/setpagedata.js"></script> <!-- Utility javascripts for all pages. -->
<script> <script>
window.onload = () => { window.onload = () => {
$('#moonImg').attr('src', '/images/moon.png?' + Date.now()); $('#moonImg').attr('src', 'images/moon.png?' + Date.now());
// update the moon image every 20 minutes if the page is left open // update the moon image every 20 minutes if the page is left open
setInterval(() => { setInterval(() => {
$('#moonImg').attr('src', '/images/moon.png?' + Date.now()); $('#moonImg').attr('src', 'images/moon.png?' + Date.now());
}, 1200000); }, 1200000);
}; };
</script> </script>
@ -16,7 +29,20 @@
<body> <body>
<div class="page-container"> <div class="page-container">
<?php include("./includes/header.inc.php"); ?> <div id="header">
<h1>wah's the weather?</h1>
<nav>
<strong>Pages:</strong>
<a href="/">now</a> |
<a href="">today</a> |
<a href="">yesterday</a> |
<a href="">today-yest</a> |
<a href="">gauges</a> |
<a href="">records</a> |
<a href="">charts</a> |
<a href="">reports</a>
</nav>
</div>
<div id="content"> <div id="content">
<h3>Almanac</h3> <h3>Almanac</h3>
<table class="almanac"> <table class="almanac">
@ -29,8 +55,8 @@
<td>Moon Rise:</td> <td>Moon Rise:</td>
<td><span data-cmxdata="moonrise"></span></td> <td><span data-cmxdata="moonrise"></span></td>
<td rowspan="3" style="width:75px; height: 75px; padding:0"><img id="moonImg" <td rowspan="3" style="width:75px; height: 75px; padding:0"><img id="moonImg"
src="/images/moon.png" alt="Moon" width="75" height="75" class="w3-image" />Visible src="images/moon.png" alt="Moon" width="75" height="75" class="w3-image" />Visible <span
<span data-cmxdata="MoonPercentAbs"></span>% data-cmxdata="MoonPercentAbs"></span>%
</td> </td>
</tr> </tr>
<tr> <tr>
@ -53,7 +79,7 @@
</table> </table>
<br><br> <br><br>
<h3>Conditions at local time <span data-cmxdata="time"></span></h3> <h3>Conditions at local time <span data-cmxdata="time"></span></h3>
<table class="mx-datatable current-conditions"> <table class="conditions-now">
<tr> <tr>
<th colspan="4">Temperature and Humidity</th> <th colspan="4">Temperature and Humidity</th>
</tr> </tr>
@ -82,8 +108,7 @@
</tr> </tr>
<tr> <tr>
<td>Temp change last hour</td> <td>Temp change last hour</td>
<td><span data-cmxdata="TempChangeLastHour"></span>&nbsp;<span data-cmxdata="tempunit"></span> <td><span data-cmxdata="TempChangeLastHour"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
</td>
<td></td> <td></td>
<td></td> <td></td>
</tr> </tr>
@ -152,13 +177,22 @@
<td><span data-cmxdata="press"></span>&nbsp;<span data-cmxdata="pressunit"></span> <td><span data-cmxdata="press"></span>&nbsp;<span data-cmxdata="pressunit"></span>
</td> </td>
<td><span data-cmxdata="presstrend"></span></td> <td><span data-cmxdata="presstrend"></span></td>
<td><span data-cmxdata="presstrendval"></span>&nbsp;<span data-cmxdata="pressunit"></span>/hr <td><span data-cmxdata="presstrendval"></span>&nbsp;<span data-cmxdata="pressunit"></span>/hr</td>
</td>
</tr> </tr>
</table> </table>
<small>Page data updated <span data-cmxdata="update"></span></small>
</div> </div>
<?php include("./includes/footer.inc.php"); ?> <div id="footer">
<div>
<span>
&copy; floppydisk 2021-2024
</span>
</div>
<div>
<span>
Powered by Cumulus MX v:<span data-cmxdata="version"></span>, b:<span data-cmxdata="build"></span>
</span>
</div>
</div>
</div> </div>
</body> </body>

View file

@ -38,7 +38,7 @@ menuSrc = [
{ title: "Cumulus Forum", menu: "w", url: "#", forum: true, new_window: true }, { title: "Cumulus Forum", menu: "w", url: "#", forum: true, new_window: true },
{ title: "Webcam", menu: "b", url: "#", webcam: true, new_window: true }, { title: "Webcam", menu: "b", url: "#", webcam: true, new_window: true },
{ title: "My Cat", menu: "b", url: "mycatpage.htm" }, { title: "My Cat", menu: "b", url: "mycatpage.htm" },
{ title: "Some Cat", menu: "b", url: "https://pixnio.com/free-/images/2020/07/26/2020-07-26-08-52-19-1200x1200.jpg", new_window: true } { title: "Some Cat", menu: "b", url: "https://pixnio.com/free-images/2020/07/26/2020-07-26-08-52-19-1200x1200.jpg", new_window: true }
] ]
} }
]; ];

View file

@ -14,7 +14,7 @@ let fixedHeader = false; // Use only true or false
let fixedFooter = true; // Use only true or false let fixedFooter = true; // Use only true or false
let headerMargin = 20; // Gap between the header and the main body let headerMargin = 20; // Gap between the header and the main body
let footerMargin = 10; // Gap between the body and the footer let footerMargin = 10; // Gap between the body and the footer
let load_menu = "/js/menu.js"; // menu file to load - path is relative to the page let load_menu = "js/menu.js"; // menu file to load - path is relative to the page
// Thats the only changes you should make unless you know better! // Thats the only changes you should make unless you know better!

File diff suppressed because one or more lines are too long

File diff suppressed because it is too large Load diff

View file

@ -1,26 +1,27 @@
/** /**
* o------------------------------------------------------------------------------o * o------------------------------------------------------------------------------o
* | This file is part of the RGraph package - you can learn more at: | * | This file is part of the RGraph package - you can learn more at: |
* | | * | |
* | http://www.rgraph.net | * | http://www.rgraph.net |
* | | * | |
* | This package is licensed under the RGraph license. For all kinds of business | * | This package is licensed under the RGraph license. For all kinds of business |
* | purposes there is a small one-time licensing fee to pay and for non | * | purposes there is a small one-time licensing fee to pay and for non |
* | commercial purposes it is free to use. You can read the full license here: | * | commercial purposes it is free to use. You can read the full license here: |
* | | * | |
* | http://www.rgraph.net/LICENSE.txt | * | http://www.rgraph.net/LICENSE.txt |
* o------------------------------------------------------------------------------o * o------------------------------------------------------------------------------o
*/ */
if (typeof (RGraph) == 'undefined') RGraph = {}; if (typeof(RGraph) == 'undefined') RGraph = {};
/** /**
* The rose chart constuctor * The rose chart constuctor
* *
* @param object canvas * @param object canvas
* @param array data * @param array data
*/ */
RGraph.Rose = function (id, data) { RGraph.Rose = function (id, data)
{
this.id = id; this.id = id;
this.canvas = document.getElementById(id); this.canvas = document.getElementById(id);
this.context = this.canvas.getContext('2d'); this.context = this.canvas.getContext('2d');
@ -56,7 +57,7 @@ RGraph.Rose = function (id, data) {
'chart.centerx': null, 'chart.centerx': null,
'chart.centery': null, 'chart.centery': null,
'chart.radius': null, 'chart.radius': null,
'chart.colors': ['rgba(255,0,0,0.5)', 'rgba(255,255,0,0.5)', 'rgba(0,255,255,0.5)', 'rgb(0,255,0)', 'gray', 'blue', 'rgb(255,128,255)', 'green', 'pink', 'gray', 'aqua'], 'chart.colors': ['rgba(255,0,0,0.5)', 'rgba(255,255,0,0.5)', 'rgba(0,255,255,0.5)', 'rgb(0,255,0)', 'gray', 'blue', 'rgb(255,128,255)','green', 'pink', 'gray', 'aqua'],
'chart.colors.sequential': false, 'chart.colors.sequential': false,
'chart.colors.alpha': null, 'chart.colors.alpha': null,
'chart.margin': 0, 'chart.margin': 0,
@ -119,7 +120,7 @@ RGraph.Rose = function (id, data) {
'chart.zoom.background': true, 'chart.zoom.background': true,
'chart.zoom.action': 'zoom', 'chart.zoom.action': 'zoom',
'chart.resizable': false, 'chart.resizable': false,
'chart.resize.handle.adjust': [0, 0], 'chart.resize.handle.adjust': [0,0],
'chart.resize.handle.background': null, 'chart.resize.handle.background': null,
'chart.adjustable': false, 'chart.adjustable': false,
'chart.ymax': null, 'chart.ymax': null,
@ -143,7 +144,7 @@ RGraph.Rose = function (id, data) {
* but it doesn't matter. * but it doesn't matter.
*/ */
var linear_data = RGraph.array_linearize(this.data); var linear_data = RGraph.array_linearize(this.data);
for (var i = 0; i < linear_data.length; ++i) { for (var i=0; i<linear_data.length; ++i) {
this["$" + i] = {} this["$" + i] = {}
} }
@ -153,7 +154,7 @@ RGraph.Rose = function (id, data) {
* done already * done already
*/ */
if (!this.canvas.__rgraph_aa_translated__) { if (!this.canvas.__rgraph_aa_translated__) {
this.context.translate(0.5, 0.5); this.context.translate(0.5,0.5);
this.canvas.__rgraph_aa_translated__ = true; this.canvas.__rgraph_aa_translated__ = true;
} }
@ -164,49 +165,52 @@ RGraph.Rose = function (id, data) {
* Register this object * Register this object
*/ */
RGraph.Register(this); RGraph.Register(this);
} }
/** /**
* A simple setter * A simple setter
* *
* @param string name The name of the property to set * @param string name The name of the property to set
* @param string value The value of the property * @param string value The value of the property
*/ */
RGraph.Rose.prototype.Set = function (name, value) { RGraph.Rose.prototype.Set = function (name, value)
{
/** /**
* This should be done first - prepend the propertyy name with "chart." if necessary * This should be done first - prepend the propertyy name with "chart." if necessary
*/ */
if (name.substr(0, 6) != 'chart.') { if (name.substr(0,6) != 'chart.') {
name = 'chart.' + name; name = 'chart.' + name;
} }
this.properties[name.toLowerCase()] = value; this.properties[name.toLowerCase()] = value;
} }
/** /**
* A simple getter * A simple getter
* *
* @param string name The name of the property to get * @param string name The name of the property to get
*/ */
RGraph.Rose.prototype.Get = function (name) { RGraph.Rose.prototype.Get = function (name)
{
/** /**
* This should be done first - prepend the property name with "chart." if necessary * This should be done first - prepend the property name with "chart." if necessary
*/ */
if (name.substr(0, 6) != 'chart.') { if (name.substr(0,6) != 'chart.') {
name = 'chart.' + name; name = 'chart.' + name;
} }
return this.properties[name.toLowerCase()]; return this.properties[name.toLowerCase()];
} }
/** /**
* This method draws the rose chart * This method draws the rose chart
*/ */
RGraph.Rose.prototype.Draw = function () { RGraph.Rose.prototype.Draw = function ()
{
/** /**
* Fire the onbeforedraw event * Fire the onbeforedraw event
*/ */
@ -240,9 +244,9 @@ RGraph.Rose.prototype.Draw = function () {
// User specified radius, centerx and centery // User specified radius, centerx and centery
if (typeof (this.Get('chart.centerx')) == 'number') this.centerx = this.Get('chart.centerx'); if (typeof(this.Get('chart.centerx')) == 'number') this.centerx = this.Get('chart.centerx');
if (typeof (this.Get('chart.centery')) == 'number') this.centery = this.Get('chart.centery'); if (typeof(this.Get('chart.centery')) == 'number') this.centery = this.Get('chart.centery');
if (typeof (this.Get('chart.radius')) == 'number') this.radius = this.Get('chart.radius'); if (typeof(this.Get('chart.radius')) == 'number') this.radius = this.Get('chart.radius');
/** /**
* Parse the colors for gradients. Its down here so that the center X/Y can be used * Parse the colors for gradients. Its down here so that the center X/Y can be used
@ -293,12 +297,13 @@ RGraph.Rose.prototype.Draw = function () {
* Fire the RGraph ondraw event * Fire the RGraph ondraw event
*/ */
RGraph.FireCustomEvent(this, 'ondraw'); RGraph.FireCustomEvent(this, 'ondraw');
} }
/** /**
* This method draws the rose charts background * This method draws the rose charts background
*/ */
RGraph.Rose.prototype.DrawBackground = function () { RGraph.Rose.prototype.DrawBackground = function ()
{
this.context.lineWidth = 1; this.context.lineWidth = 1;
@ -307,7 +312,7 @@ RGraph.Rose.prototype.DrawBackground = function () {
// Draw the background grey circles/spokes // Draw the background grey circles/spokes
if (this.properties['chart.background.grid']) { if (this.properties['chart.background.grid']) {
if (typeof (this.properties['chart.background.grid.count']) == 'number') { if (typeof(this.properties['chart.background.grid.count']) == 'number') {
this.properties['chart.background.grid.size'] = this.radius / this.properties['chart.background.grid.count']; this.properties['chart.background.grid.size'] = this.radius / this.properties['chart.background.grid.count'];
} }
@ -315,7 +320,7 @@ RGraph.Rose.prototype.DrawBackground = function () {
this.context.strokeStyle = this.properties['chart.background.grid.color']; this.context.strokeStyle = this.properties['chart.background.grid.color'];
// Radius must be greater than 0 for Opera to work // Radius must be greater than 0 for Opera to work
for (var i = this.properties['chart.background.grid.size']; i <= this.radius; i += this.properties['chart.background.grid.size']) { for (var i=this.properties['chart.background.grid.size']; i<=this.radius; i+=this.properties['chart.background.grid.size']) {
//this.context.moveTo(this.centerx + i, this.centery); //this.context.moveTo(this.centerx + i, this.centery);
@ -336,11 +341,11 @@ RGraph.Rose.prototype.DrawBackground = function () {
// Draw the background lines that go from the center outwards // Draw the background lines that go from the center outwards
this.context.beginPath(); this.context.beginPath();
if (typeof (this.properties['chart.background.grid.spokes']) == 'number') { if (typeof(this.properties['chart.background.grid.spokes']) == 'number') {
var num = (360 / this.properties['chart.background.grid.spokes']); var num = (360 / this.properties['chart.background.grid.spokes']);
for (var i = num; i <= 360; i += num) { for (var i=num; i<=360; i+=num) {
// Radius must be greater than 0 for Opera to work // Radius must be greater than 0 for Opera to work
this.context.arc(this.centerx, this.context.arc(this.centerx,
@ -353,14 +358,14 @@ RGraph.Rose.prototype.DrawBackground = function () {
this.context.lineTo(this.centerx, this.centery); this.context.lineTo(this.centerx, this.centery);
} }
} else { } else {
for (var i = 15; i <= 360; i += 15) { for (var i=15; i<=360; i+=15) {
// Radius must be greater than 0 for Opera to work // Radius must be greater than 0 for Opera to work
this.context.arc(this.centerx, this.context.arc(this.centerx,
this.centery, this.centery,
this.radius, this.radius,
(i / (180 / PI)) - HALFPI, (i / (180/ PI)) - HALFPI,
((i + 0.0001) / (180 / PI)) - HALFPI, ((i + 0.0001) / (180/ PI)) - HALFPI,
false); false);
this.context.lineTo(this.centerx, this.centery); this.context.lineTo(this.centerx, this.centery);
@ -376,8 +381,8 @@ RGraph.Rose.prototype.DrawBackground = function () {
this.context.strokeStyle = this.Get('chart.background.axes.color'); this.context.strokeStyle = this.Get('chart.background.axes.color');
// Draw the X axis // Draw the X axis
this.context.moveTo(this.centerx - this.radius, Math.round(this.centery)); this.context.moveTo(this.centerx - this.radius, Math.round(this.centery) );
this.context.lineTo(this.centerx + this.radius, Math.round(this.centery)); this.context.lineTo(this.centerx + this.radius, Math.round(this.centery) );
// Draw the X ends // Draw the X ends
this.context.moveTo(Math.round(this.centerx - this.radius), this.centery - 5); this.context.moveTo(Math.round(this.centerx - this.radius), this.centery - 5);
@ -386,13 +391,13 @@ RGraph.Rose.prototype.DrawBackground = function () {
this.context.lineTo(Math.round(this.centerx + this.radius), this.centery + 5); this.context.lineTo(Math.round(this.centerx + this.radius), this.centery + 5);
// Draw the X check marks // Draw the X check marks
for (var i = (this.centerx - this.radius); i < (this.centerx + this.radius); i += (this.radius / 5)) { for (var i=(this.centerx - this.radius); i<(this.centerx + this.radius); i+=(this.radius / 5)) {
this.context.moveTo(Math.round(i), this.centery - 3); this.context.moveTo(Math.round(i), this.centery - 3);
this.context.lineTo(Math.round(i), this.centery + 3.5); this.context.lineTo(Math.round(i), this.centery + 3.5);
} }
// Draw the Y check marks // Draw the Y check marks
for (var i = (this.centery - this.radius); i < (this.centery + this.radius); i += (this.radius / 5)) { for (var i=(this.centery - this.radius); i<(this.centery + this.radius); i+=(this.radius / 5)) {
this.context.moveTo(this.centerx - 3, Math.round(i)); this.context.moveTo(this.centerx - 3, Math.round(i));
this.context.lineTo(this.centerx + 3, Math.round(i)); this.context.lineTo(this.centerx + 3, Math.round(i));
} }
@ -412,14 +417,15 @@ RGraph.Rose.prototype.DrawBackground = function () {
this.context.closePath(); this.context.closePath();
this.context.stroke(); this.context.stroke();
} }
} }
/** /**
* This method draws the data on the graph * This method draws the data on the graph
*/ */
RGraph.Rose.prototype.DrawRose = function () { RGraph.Rose.prototype.DrawRose = function ()
{
var max = 0; var max = 0;
var data = this.data; var data = this.data;
var margin = RGraph.degrees2Radians(this.Get('chart.margin')); var margin = RGraph.degrees2Radians(this.Get('chart.margin'));
@ -433,10 +439,10 @@ RGraph.Rose.prototype.DrawRose = function () {
// Work out the maximum value and the sum // Work out the maximum value and the sum
if (!this.Get('chart.ymax')) { if (!this.Get('chart.ymax')) {
// Work out the max // Work out the max
for (var i = 0; i < data.length; ++i) { for (var i=0; i<data.length; ++i) {
if (typeof (data[i]) == 'number') { if (typeof(data[i]) == 'number') {
max = Math.max(max, data[i]); max = Math.max(max, data[i]);
} else if (typeof (data[i]) == 'object' && this.Get('chart.variant') == 'non-equi-angular') { } else if (typeof(data[i]) == 'object' && this.Get('chart.variant') == 'non-equi-angular') {
max = Math.max(max, data[i][0]); max = Math.max(max, data[i][0]);
// Fallback is stacked // Fallback is stacked
@ -476,17 +482,17 @@ RGraph.Rose.prototype.DrawRose = function () {
/******************************************************* /*******************************************************
* A non-equi-angular Rose chart * A non-equi-angular Rose chart
*******************************************************/ *******************************************************/
if (typeof (this.Get('chart.variant')) == 'string' && this.Get('chart.variant') == 'non-equi-angular') { if (typeof(this.Get('chart.variant')) == 'string' && this.Get('chart.variant') == 'non-equi-angular') {
/******************************************************* /*******************************************************
* NON-EQUI-ANGULAR GOES HERE * NON-EQUI-ANGULAR GOES HERE
*******************************************************/ *******************************************************/
var total = 0; var total=0;
for (var i = 0; i < data.length; ++i) { for (var i=0; i<data.length; ++i) {
total += data[i][1]; total += data[i][1];
} }
for (var i = 0; i < this.data.length; ++i) { for (var i=0; i<this.data.length; ++i) {
var segmentRadians = ((this.data[i][1] / total) * TWOPI); var segmentRadians = ((this.data[i][1] / total) * TWOPI);
var radius = ((this.data[i][0] - this.Get('chart.ymin')) / (this.max - this.Get('chart.ymin'))) * this.radius; var radius = ((this.data[i][0] - this.Get('chart.ymin')) / (this.max - this.Get('chart.ymin'))) * this.radius;
@ -501,8 +507,8 @@ RGraph.Rose.prototype.DrawRose = function () {
this.context.beginPath(); // Begin the segment this.context.beginPath(); // Begin the segment
// var startAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI + margin; // var startAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI + margin;
// var endAngle = ((this.startRadians + segmentRadians) * this.Get('chart.animation.roundrobin.factor')) - HALFPI - margin; // var endAngle = ((this.startRadians + segmentRadians) * this.Get('chart.animation.roundrobin.factor')) - HALFPI - margin;
var startAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI + margin - segmentRadians / 2; var startAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI + margin - segmentRadians / 2;
var endAngle = ((this.startRadians + segmentRadians) * this.Get('chart.animation.roundrobin.factor')) - HALFPI - margin - segmentRadians / 2; var endAngle = ((this.startRadians + segmentRadians) * this.Get('chart.animation.roundrobin.factor')) - HALFPI - margin - segmentRadians / 2;
@ -543,7 +549,7 @@ RGraph.Rose.prototype.DrawRose = function () {
/******************************************************* /*******************************************************
* Draw regular segments here * Draw regular segments here
*******************************************************/ *******************************************************/
for (var i = 0; i < this.data.length; ++i) { for (var i=0; i<this.data.length; ++i) {
this.context.strokeStyle = this.Get('chart.strokestyle'); this.context.strokeStyle = this.Get('chart.strokestyle');
this.context.fillStyle = this.Get('chart.colors')[0]; this.context.fillStyle = this.Get('chart.colors')[0];
@ -557,14 +563,14 @@ RGraph.Rose.prototype.DrawRose = function () {
var segmentRadians = (1 / this.data.length) * TWOPI; var segmentRadians = (1 / this.data.length) * TWOPI;
if (typeof (this.data[i]) == 'number') { if (typeof(this.data[i]) == 'number') {
this.context.beginPath(); // Begin the segment this.context.beginPath(); // Begin the segment
var radius = ((this.data[i] - this.Get('chart.ymin')) / (this.max - this.Get('chart.ymin'))) * this.radius; var radius = ((this.data[i] - this.Get('chart.ymin')) / (this.max - this.Get('chart.ymin'))) * this.radius;
radius = radius * this.properties['chart.animation.grow.multiplier']; radius = radius * this.properties['chart.animation.grow.multiplier'];
// var startAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI + margin; // var startAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI + margin;
// var endAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) + (segmentRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI - margin; // var endAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) + (segmentRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI - margin;
var startAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI + margin - segmentRadians / 2; var startAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI + margin - segmentRadians / 2;
var endAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) + (segmentRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI - margin - segmentRadians / 2; var endAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) + (segmentRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI - margin - segmentRadians / 2;
@ -601,15 +607,15 @@ RGraph.Rose.prototype.DrawRose = function () {
/******************************************************* /*******************************************************
* Draw a stacked segment * Draw a stacked segment
*******************************************************/ *******************************************************/
} else if (typeof (this.data[i]) == 'object') { } else if (typeof(this.data[i]) == 'object') {
var margin = this.Get('chart.margin') / (180 / PI); var margin = this.Get('chart.margin') / (180 / PI);
for (var j = 0; j < this.data[i].length; ++j) { for (var j=0; j<this.data[i].length; ++j) {
var startAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI + margin; var startAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI + margin;
var endAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor')) + (segmentRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI - margin; var endAngle = (this.startRadians * this.Get('chart.animation.roundrobin.factor'))+ (segmentRadians * this.Get('chart.animation.roundrobin.factor')) - HALFPI - margin;
var exploded = this.getexploded(i, startAngle, endAngle, this.Get('chart.exploded')); var exploded = this.getexploded(i, startAngle, endAngle, this.Get('chart.exploded'));
var explodedX = exploded[0]; var explodedX = exploded[0];
@ -703,13 +709,14 @@ RGraph.Rose.prototype.DrawRose = function () {
this.centerx, this.centerx,
this.Get('chart.title.size') ? this.Get('chart.title.size') : this.Get('chart.text.size') + 2); this.Get('chart.title.size') ? this.Get('chart.title.size') : this.Get('chart.text.size') + 2);
} }
} }
/** /**
* Unsuprisingly, draws the labels * Unsuprisingly, draws the labels
*/ */
RGraph.Rose.prototype.DrawLabels = function () { RGraph.Rose.prototype.DrawLabels = function ()
{
this.context.lineWidth = 1; this.context.lineWidth = 1;
var key = this.Get('chart.key'); var key = this.Get('chart.key');
@ -731,13 +738,13 @@ RGraph.Rose.prototype.DrawLabels = function () {
var units_post = this.Get('chart.units.post'); var units_post = this.Get('chart.units.post');
// Draw any circular labels // Draw any circular labels
if (typeof (this.Get('chart.labels')) == 'object' && this.Get('chart.labels')) { if (typeof(this.Get('chart.labels')) == 'object' && this.Get('chart.labels')) {
this.DrawCircularLabels(context, this.Get('chart.labels'), font_face, font_size, r + 10); this.DrawCircularLabels(context, this.Get('chart.labels'), font_face, font_size, r + 10);
} }
// Size can be specified seperately for the scale now // Size can be specified seperately for the scale now
if (typeof (this.properties['chart.text.size.scale']) == 'number') { if (typeof(this.properties['chart.text.size.scale']) == 'number') {
font_size = this.properties['chart.text.size.scale']; font_size = this.properties['chart.text.size.scale'];
} }
@ -781,23 +788,24 @@ RGraph.Rose.prototype.DrawLabels = function () {
} }
if (axes.length > 0) { if (axes.length > 0) {
RGraph.Text(context, font_face, font_size, this.centerx, this.centery, typeof (this.Get('chart.ymin')) == 'number' ? RGraph.number_format(this, Number(this.Get('chart.ymin')).toFixed(this.Get('chart.scale.decimals')), units_pre, units_post) : '0', 'center', 'center', true, false, color); RGraph.Text(context, font_face, font_size, this.centerx, this.centery, typeof(this.Get('chart.ymin')) == 'number' ? RGraph.number_format(this, Number(this.Get('chart.ymin')).toFixed(this.Get('chart.scale.decimals')), units_pre, units_post) : '0', 'center', 'center', true, false, color);
}
} }
}
/** /**
* Draws the circular labels that go around the charts * Draws the circular labels that go around the charts
* *
* @param labels array The labels that go around the chart * @param labels array The labels that go around the chart
*/ */
RGraph.Rose.prototype.DrawCircularLabels = function (context, labels, font_face, font_size, r) { RGraph.Rose.prototype.DrawCircularLabels = function (context, labels, font_face, font_size, r)
{
var variant = this.Get('chart.variant'); var variant = this.Get('chart.variant');
var position = this.Get('chart.labels.position'); var position = this.Get('chart.labels.position');
var r = r + 5 + this.Get('chart.labels.offset'); var r = r + 5 + this.Get('chart.labels.offset');
for (var i = 0; i < this.angles.length; ++i) { for (var i=0; i<this.angles.length; ++i) {
if (typeof (variant) == 'string' && variant == 'non-equi-angular') { if (typeof(variant) == 'string' && variant == 'non-equi-angular') {
var a = Number(this.angles[i][0]) + ((this.angles[i][1] - this.angles[i][0]) / 2); var a = Number(this.angles[i][0]) + ((this.angles[i][1] - this.angles[i][0]) / 2);
} else { } else {
var a = (TWOPI / labels.length) * (i + 1) - (TWOPI / (labels.length * 2)); var a = (TWOPI / labels.length) * (i + 1) - (TWOPI / (labels.length * 2));
@ -818,7 +826,7 @@ RGraph.Rose.prototype.DrawCircularLabels = function (context, labels, font_face,
RGraph.Text(context, font_face, font_size, x, y, String(labels[i]), 'center', halign); RGraph.Text(context, font_face, font_size, x, y, String(labels[i]), 'center', halign);
} }
} }
@ -845,18 +853,19 @@ RGraph.Rose.prototype.DrawCircularLabels = function (context, labels, font_face,
/** /**
* This function is for use with circular graph types, eg the Pie or Rose. Pass it your event object * This function is for use with circular graph types, eg the Pie or Rose. Pass it your event object
* and it will pass you back the corresponding segment details as an array: * and it will pass you back the corresponding segment details as an array:
* *
* [x, y, r, startAngle, endAngle] * [x, y, r, startAngle, endAngle]
* *
* Angles are measured in degrees, and are measured from the "east" axis (just like the canvas). * Angles are measured in degrees, and are measured from the "east" axis (just like the canvas).
* *
* @param object e Your event object * @param object e Your event object
*/ */
RGraph.Rose.prototype.getShape = RGraph.Rose.prototype.getShape =
RGraph.Rose.prototype.getSegment = function (e) { RGraph.Rose.prototype.getSegment = function (e)
{
RGraph.FixEventObject(e); RGraph.FixEventObject(e);
var canvas = this.canvas; var canvas = this.canvas;
@ -867,7 +876,7 @@ RGraph.Rose.prototype.getShape =
/** /**
* Go through all of the angles checking each one * Go through all of the angles checking each one
*/ */
for (var i = 0; i < angles.length; ++i) { for (var i=0; i<angles.length ; ++i) {
var angleStart = angles[i][0]; var angleStart = angles[i][0];
var angleEnd = angles[i][1]; var angleEnd = angles[i][1];
@ -937,21 +946,22 @@ RGraph.Rose.prototype.getShape =
/** /**
* Returns any exploded for a particular segment * Returns any exploded for a particular segment
*/ */
RGraph.Rose.prototype.getexploded = function (index, startAngle, endAngle, exploded) { RGraph.Rose.prototype.getexploded = function (index, startAngle, endAngle, exploded)
{
var explodedx, explodedy; var explodedx, explodedy;
/** /**
* Retrieve any exploded - the exploded can be an array of numbers or a single number * Retrieve any exploded - the exploded can be an array of numbers or a single number
* (which is applied to all segments) * (which is applied to all segments)
*/ */
if (typeof (exploded) == 'object' && typeof (exploded[index]) == 'number') { if (typeof(exploded) == 'object' && typeof(exploded[index]) == 'number') {
explodedx = Math.cos(((endAngle - startAngle) / 2) + startAngle) * exploded[index]; explodedx = Math.cos(((endAngle - startAngle) / 2) + startAngle) * exploded[index];
explodedy = Math.sin(((endAngle - startAngle) / 2) + startAngle) * exploded[index]; explodedy = Math.sin(((endAngle - startAngle) / 2) + startAngle) * exploded[index];
} else if (typeof (exploded) == 'number') { } else if (typeof(exploded) == 'number') {
explodedx = Math.cos(((endAngle - startAngle) / 2) + startAngle) * exploded; explodedx = Math.cos(((endAngle - startAngle) / 2) + startAngle) * exploded;
explodedy = Math.sin(((endAngle - startAngle) / 2) + startAngle) * exploded; explodedy = Math.sin(((endAngle - startAngle) / 2) + startAngle) * exploded;
@ -961,17 +971,18 @@ RGraph.Rose.prototype.getexploded = function (index, startAngle, endAngle, explo
} }
return [explodedx, explodedy]; return [explodedx, explodedy];
} }
/** /**
* This function facilitates the installation of tooltip event listeners if * This function facilitates the installation of tooltip event listeners if
* tooltips are defined. * tooltips are defined.
*/ */
RGraph.Rose.prototype.AllowTooltips = function () { RGraph.Rose.prototype.AllowTooltips = function ()
// Preload any tooltip /images that are used in the tooltips {
RGraph.PreLoadTooltip / images(this); // Preload any tooltip images that are used in the tooltips
RGraph.PreLoadTooltipImages(this);
/** /**
@ -993,16 +1004,17 @@ RGraph.Rose.prototype.AllowTooltips = function () {
* function that actually shows the appropriate tooltip (if any). * function that actually shows the appropriate tooltip (if any).
*/ */
RGraph.InstallCanvasMouseupTooltipListener(this); RGraph.InstallCanvasMouseupTooltipListener(this);
} }
/** /**
* Each object type has its own Highlight() function which highlights the appropriate shape * Each object type has its own Highlight() function which highlights the appropriate shape
* *
* @param object shape The shape to highlight * @param object shape The shape to highlight
*/ */
RGraph.Rose.prototype.Highlight = function (shape) { RGraph.Rose.prototype.Highlight = function (shape)
{
if (this.Get('chart.tooltips.highlight')) { if (this.Get('chart.tooltips.highlight')) {
// Add the new segment highlight // Add the new segment highlight
this.context.beginPath(); this.context.beginPath();
@ -1022,18 +1034,19 @@ RGraph.Rose.prototype.Highlight = function (shape) {
this.context.stroke(); this.context.stroke();
this.context.fill(); this.context.fill();
} }
} }
/** /**
* The getObjectByXY() worker method. Don't call this call: * The getObjectByXY() worker method. Don't call this call:
* *
* RGraph.ObjectRegistry.getObjectByXY(e) * RGraph.ObjectRegistry.getObjectByXY(e)
* *
* @param object e The event object * @param object e The event object
*/ */
RGraph.Rose.prototype.getObjectByXY = function (e) { RGraph.Rose.prototype.getObjectByXY = function (e)
{
var mouseXY = RGraph.getMouseXY(e); var mouseXY = RGraph.getMouseXY(e);
// Work out the radius // Work out the radius
@ -1049,19 +1062,20 @@ RGraph.Rose.prototype.getObjectByXY = function (e) {
return this; return this;
} }
} }
/** /**
* This function positions a tooltip when it is displayed * This function positions a tooltip when it is displayed
* *
* @param obj object The chart object * @param obj object The chart object
* @param int x The X coordinate specified for the tooltip * @param int x The X coordinate specified for the tooltip
* @param int y The Y coordinate specified for the tooltip * @param int y The Y coordinate specified for the tooltip
* @param objec tooltip The tooltips DIV element * @param objec tooltip The tooltips DIV element
*/ */
RGraph.Rose.prototype.positionTooltip = function (obj, x, y, tooltip, idx) { RGraph.Rose.prototype.positionTooltip = function (obj, x, y, tooltip, idx)
{
var coordX = obj.angles[idx][4]; var coordX = obj.angles[idx][4];
var coordY = obj.angles[idx][5]; var coordY = obj.angles[idx][5];
@ -1092,32 +1106,33 @@ RGraph.Rose.prototype.positionTooltip = function (obj, x, y, tooltip, idx) {
// LEFT edge // LEFT edge
if ((canvasXY[0] + coordX + (Math.cos(angleCenter) * radius) - (width / 2)) < 10) { if ((canvasXY[0] + coordX + (Math.cos(angleCenter) * radius) - (width / 2)) < 10) {
tooltip.style.left = (canvasXY[0] + coordX + (Math.cos(angleCenter) * radius) - (width * 0.1)) + 'px'; tooltip.style.left = (canvasXY[0] + coordX + (Math.cos(angleCenter) * radius)- (width * 0.1)) + 'px';
tooltip.style.top = (canvasXY[1] + coordY + (Math.sin(angleCenter) * radius) - height - 5) + 'px'; tooltip.style.top = (canvasXY[1] + coordY + (Math.sin(angleCenter) * radius)- height - 5) + 'px';
img.style.left = ((width * 0.1) - 8.5) + 'px'; img.style.left = ((width * 0.1) - 8.5) + 'px';
// RIGHT edge // RIGHT edge
} else if ((canvasXY[0] + coordX + (Math.cos(angleCenter) * radius) + (width / 2)) > (document.body.offsetWidth - 10)) { } else if ((canvasXY[0] + coordX + (Math.cos(angleCenter) * radius) + (width / 2)) > (document.body.offsetWidth - 10) ) {
tooltip.style.left = (canvasXY[0] + coordX + (Math.cos(angleCenter) * radius) - (width * 0.9)) + 'px'; tooltip.style.left = (canvasXY[0] + coordX + (Math.cos(angleCenter) * radius) - (width * 0.9)) + 'px';
tooltip.style.top = (canvasXY[1] + coordY + (Math.sin(angleCenter) * radius) - height - 5) + 'px'; tooltip.style.top = (canvasXY[1] + coordY + (Math.sin(angleCenter) * radius)- height - 5) + 'px';
img.style.left = ((width * 0.9) - 8.5) + 'px'; img.style.left = ((width * 0.9) - 8.5) + 'px';
// Default positioning - CENTERED // Default positioning - CENTERED
} else { } else {
tooltip.style.left = (canvasXY[0] + coordX + (Math.cos(angleCenter) * radius) - (width / 2)) + 'px'; tooltip.style.left = (canvasXY[0] + coordX + (Math.cos(angleCenter) * radius)- (width / 2)) + 'px';
tooltip.style.top = (canvasXY[1] + coordY + (Math.sin(angleCenter) * radius) - height - 5) + 'px'; tooltip.style.top = (canvasXY[1] + coordY + (Math.sin(angleCenter) * radius)- height - 5) + 'px';
img.style.left = ((width * 0.5) - 8.5) + 'px'; img.style.left = ((width * 0.5) - 8.5) + 'px';
} }
} }
/** /**
* This method gives you the relevant radius for a particular value * This method gives you the relevant radius for a particular value
* *
* @param number value The relevant value to get the radius for * @param number value The relevant value to get the radius for
*/ */
RGraph.Rose.prototype.getRadius = function (value) { RGraph.Rose.prototype.getRadius = function (value)
{
// Range checking (the Rose minimum is always 0) // Range checking (the Rose minimum is always 0)
if (value < 0 || value > this.max) { if (value < 0 || value > this.max) {
return null; return null;
@ -1126,15 +1141,16 @@ RGraph.Rose.prototype.getRadius = function (value) {
var r = (value / this.max) * this.radius; var r = (value / this.max) * this.radius;
return r; return r;
} }
/** /**
* This allows for easy specification of gradients * This allows for easy specification of gradients
*/ */
RGraph.Rose.prototype.parseColors = function () { RGraph.Rose.prototype.parseColors = function ()
for (var i = 0; i < this.properties['chart.colors'].length; ++i) { {
for (var i=0; i<this.properties['chart.colors'].length; ++i) {
this.properties['chart.colors'][i] = this.parseSingleColorForGradient(this.properties['chart.colors'][i]); this.properties['chart.colors'][i] = this.parseSingleColorForGradient(this.properties['chart.colors'][i]);
} }
@ -1142,7 +1158,7 @@ RGraph.Rose.prototype.parseColors = function () {
* Key colors * Key colors
*/ */
if (!RGraph.is_null(this.properties['chart.key.colors'])) { if (!RGraph.is_null(this.properties['chart.key.colors'])) {
for (var i = 0; i < this.properties['chart.key.colors'].length; ++i) { for (var i=0; i<this.properties['chart.key.colors'].length; ++i) {
this.properties['chart.key.colors'][i] = this.parseSingleColorForGradient(this.properties['chart.key.colors'][i]); this.properties['chart.key.colors'][i] = this.parseSingleColorForGradient(this.properties['chart.key.colors'][i]);
} }
} }
@ -1151,18 +1167,19 @@ RGraph.Rose.prototype.parseColors = function () {
this.properties['chart.title.color'] = this.parseSingleColorForGradient(this.properties['chart.title.color']); this.properties['chart.title.color'] = this.parseSingleColorForGradient(this.properties['chart.title.color']);
this.properties['chart.highlight.fill'] = this.parseSingleColorForGradient(this.properties['chart.highlight.fill']); this.properties['chart.highlight.fill'] = this.parseSingleColorForGradient(this.properties['chart.highlight.fill']);
this.properties['chart.highlight.stroke'] = this.parseSingleColorForGradient(this.properties['chart.highlight.stroke']); this.properties['chart.highlight.stroke'] = this.parseSingleColorForGradient(this.properties['chart.highlight.stroke']);
} }
/** /**
* This parses a single color value * This parses a single color value
*/ */
RGraph.Rose.prototype.parseSingleColorForGradient = function (color) { RGraph.Rose.prototype.parseSingleColorForGradient = function (color)
{
var canvas = this.canvas; var canvas = this.canvas;
var context = this.context; var context = this.context;
if (!color || typeof (color) != 'string') { if (!color || typeof(color) != 'string') {
return color; return color;
} }
@ -1178,10 +1195,10 @@ RGraph.Rose.prototype.parseSingleColorForGradient = function (color) {
grad.addColorStop(0, RGraph.trim(parts[0])); grad.addColorStop(0, RGraph.trim(parts[0]));
for (var j = 1; j < parts.length; ++j) { for (var j=1; j<parts.length; ++j) {
grad.addColorStop(j * diff, RGraph.trim(parts[j])); grad.addColorStop(j * diff, RGraph.trim(parts[j]));
} }
} }
return grad ? grad : color; return grad ? grad : color;
} }

View file

@ -43,7 +43,7 @@ var steelseries = (function () {
minValue = (undefined === parameters.minValue ? 0 : parameters.minValue), minValue = (undefined === parameters.minValue ? 0 : parameters.minValue),
maxValue = (undefined === parameters.maxValue ? (minValue + 100) : parameters.maxValue), maxValue = (undefined === parameters.maxValue ? (minValue + 100) : parameters.maxValue),
niceScale = (undefined === parameters.niceScale ? true : parameters.niceScale), niceScale = (undefined === parameters.niceScale ? true : parameters.niceScale),
threshold = (undefined === parameters.threshold ? (maxValue - minValue) / 2 + minValue : parameters.threshold), threshold = (undefined === parameters.threshold ? (maxValue - minValue) / 2 + minValue: parameters.threshold),
thresholdRising = (undefined === parameters.thresholdRising ? true : parameters.thresholdRising), thresholdRising = (undefined === parameters.thresholdRising ? true : parameters.thresholdRising),
section = (undefined === parameters.section ? null : parameters.section), section = (undefined === parameters.section ? null : parameters.section),
area = (undefined === parameters.area ? null : parameters.area), area = (undefined === parameters.area ? null : parameters.area),
@ -919,7 +919,7 @@ var steelseries = (function () {
}; };
// do we have a callback function to process? // do we have a callback function to process?
if (callback && typeof (callback) === "function") { if (callback && typeof(callback) === "function") {
tween.onMotionFinished = callback; tween.onMotionFinished = callback;
} }
@ -969,30 +969,26 @@ var steelseries = (function () {
this.setTitleString = function (title) { this.setTitleString = function (title) {
titleString = title; titleString = title;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setUnitString = function (unit) { this.setUnitString = function (unit) {
unitString = unit; unitString = unit;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setMinValue = function (value) { this.setMinValue = function (value) {
minValue = parseFloat(value); minValue = parseFloat(value);
resetBuffers({ resetBuffers({frame: true,
frame: true, background: true});
background: true init({frame: true,
}); background: true});
init({
frame: true,
background: true
});
this.repaint(); this.repaint();
return this; return this;
}; };
@ -1003,14 +999,10 @@ var steelseries = (function () {
this.setMaxValue = function (value) { this.setMaxValue = function (value) {
maxValue = parseFloat(value); maxValue = parseFloat(value);
resetBuffers({ resetBuffers({frame: true,
frame: true, background: true});
background: true init({frame: true,
}); background: true});
init({
frame: true,
background: true
});
this.repaint(); this.repaint();
return this; return this;
}; };
@ -1023,20 +1015,17 @@ var steelseries = (function () {
newValue = parseFloat(newValue); newValue = parseFloat(newValue);
var targetValue = newValue < minValue ? minValue : (newValue > maxValue ? maxValue : newValue); var targetValue = newValue < minValue ? minValue : (newValue > maxValue ? maxValue : newValue);
threshold = targetValue; threshold = targetValue;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setArea = function (areaVal) { this.setArea = function (areaVal) {
area = areaVal; area = areaVal;
resetBuffers({ resetBuffers({background: true,
background: true, foreground: true});
foreground: true init({background: true,
});
init({
background: true,
foreground: true foreground: true
}); });
this.repaint(); this.repaint();
@ -1045,12 +1034,9 @@ var steelseries = (function () {
this.setSection = function (areaSec) { this.setSection = function (areaSec) {
section = areaSec; section = areaSec;
resetBuffers({ resetBuffers({background: true,
background: true, foreground: true});
foreground: true init({background: true,
});
init({
background: true,
foreground: true foreground: true
}); });
this.repaint(); this.repaint();
@ -1079,21 +1065,19 @@ var steelseries = (function () {
}; };
this.setFrameDesign = function (newFrameDesign) { this.setFrameDesign = function (newFrameDesign) {
resetBuffers({ frame: true }); resetBuffers({frame: true});
frameDesign = newFrameDesign; frameDesign = newFrameDesign;
init({ frame: true }); init({frame: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setBackgroundColor = function (newBackgroundColor) { this.setBackgroundColor = function (newBackgroundColor) {
resetBuffers({ resetBuffers({background: true,
background: true,
pointer: (pointerType.type === 'type2' || pointerType.type === 'type13' ? true : false) // type2 & 13 depend on background pointer: (pointerType.type === 'type2' || pointerType.type === 'type13' ? true : false) // type2 & 13 depend on background
}); });
backgroundColor = newBackgroundColor; backgroundColor = newBackgroundColor;
init({ init({background: true, // type2 & 13 depend on background
background: true, // type2 & 13 depend on background
pointer: (pointerType.type === 'type2' || pointerType.type === 'type13' ? true : false) pointer: (pointerType.type === 'type2' || pointerType.type === 'type13' ? true : false)
}); });
this.repaint(); this.repaint();
@ -1101,21 +1085,19 @@ var steelseries = (function () {
}; };
this.setForegroundType = function (newForegroundType) { this.setForegroundType = function (newForegroundType) {
resetBuffers({ foreground: true }); resetBuffers({foreground: true});
foregroundType = newForegroundType; foregroundType = newForegroundType;
init({ foreground: true }); init({foreground: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setPointerType = function (newPointerType) { this.setPointerType = function (newPointerType) {
resetBuffers({ resetBuffers({pointer: true,
pointer: true,
foreground: true foreground: true
}); });
pointerType = newPointerType; pointerType = newPointerType;
init({ init({pointer: true,
pointer: true,
foreground: true foreground: true
}); });
this.repaint(); this.repaint();
@ -1123,25 +1105,25 @@ var steelseries = (function () {
}; };
this.setPointerColor = function (newPointerColor) { this.setPointerColor = function (newPointerColor) {
resetBuffers({ pointer: true }); resetBuffers({pointer: true});
pointerColor = newPointerColor; pointerColor = newPointerColor;
init({ pointer: true }); init({pointer: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setLedColor = function (newLedColor) { this.setLedColor = function (newLedColor) {
resetBuffers({ led: true }); resetBuffers({led: true});
ledColor = newLedColor; ledColor = newLedColor;
init({ led: true }); init({led: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setUserLedColor = function (newLedColor) { this.setUserLedColor = function (newLedColor) {
resetBuffers({ userLed: true }); resetBuffers({userLed: true});
userLedColor = newLedColor; userLedColor = newLedColor;
init({ userLed: true }); init({userLed: true});
this.repaint(); this.repaint();
return this; return this;
}; };
@ -1195,8 +1177,8 @@ var steelseries = (function () {
this.setLcdColor = function (newLcdColor) { this.setLcdColor = function (newLcdColor) {
lcdColor = newLcdColor; lcdColor = newLcdColor;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
@ -1215,32 +1197,30 @@ var steelseries = (function () {
this.setFractionalScaleDecimals = function (decimals) { this.setFractionalScaleDecimals = function (decimals) {
fractionalScaleDecimals = parseInt(decimals, 10); fractionalScaleDecimals = parseInt(decimals, 10);
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setLabelNumberFormat = function (format) { this.setLabelNumberFormat = function (format) {
labelNumberFormat = format; labelNumberFormat = format;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.repaint = function () { this.repaint = function () {
if (!initialized) { if (!initialized) {
init({ init({frame: true,
frame: true,
background: true, background: true,
led: true, led: true,
userLed: true, userLed: true,
pointer: true, pointer: true,
trend: true, trend: true,
foreground: true, foreground: true,
odo: true odo: true});
});
} }
mainCtx.clearRect(0, 0, size, size); mainCtx.clearRect(0, 0, size, size);
@ -1347,7 +1327,7 @@ var steelseries = (function () {
minValue = (undefined === parameters.minValue ? 0 : parameters.minValue), minValue = (undefined === parameters.minValue ? 0 : parameters.minValue),
maxValue = (undefined === parameters.maxValue ? (minValue + 100) : parameters.maxValue), maxValue = (undefined === parameters.maxValue ? (minValue + 100) : parameters.maxValue),
niceScale = (undefined === parameters.niceScale ? true : parameters.niceScale), niceScale = (undefined === parameters.niceScale ? true : parameters.niceScale),
threshold = (undefined === parameters.threshold ? (maxValue - minValue) / 2 + minValue : parameters.threshold), threshold = (undefined === parameters.threshold ? (maxValue - minValue) / 2 + minValue: parameters.threshold),
thresholdRising = (undefined === parameters.thresholdRising ? true : parameters.thresholdRising), thresholdRising = (undefined === parameters.thresholdRising ? true : parameters.thresholdRising),
section = (undefined === parameters.section ? null : parameters.section), section = (undefined === parameters.section ? null : parameters.section),
useSectionColors = (undefined === parameters.useSectionColors ? false : parameters.useSectionColors), useSectionColors = (undefined === parameters.useSectionColors ? false : parameters.useSectionColors),
@ -1688,11 +1668,9 @@ var steelseries = (function () {
sectionAngles = []; sectionAngles = [];
do { do {
sectionIndex--; sectionIndex--;
sectionAngles.push({ sectionAngles.push({start: (((section[sectionIndex].start + Math.abs(minValue)) / (maxValue - minValue)) * degAngleRange),
start: (((section[sectionIndex].start + Math.abs(minValue)) / (maxValue - minValue)) * degAngleRange),
stop: (((section[sectionIndex].stop + Math.abs(minValue)) / (maxValue - minValue)) * degAngleRange), stop: (((section[sectionIndex].stop + Math.abs(minValue)) / (maxValue - minValue)) * degAngleRange),
color: customColorDef(section[sectionIndex].color) color: customColorDef(section[sectionIndex].color)});
});
} while (0 < sectionIndex); } while (0 < sectionIndex);
} }
@ -2091,7 +2069,7 @@ var steelseries = (function () {
}; };
// do we have a callback function to process? // do we have a callback function to process?
if (callback && typeof (callback) === "function") { if (callback && typeof(callback) === "function") {
tween.onMotionFinished = callback; tween.onMotionFinished = callback;
} }
@ -2101,55 +2079,51 @@ var steelseries = (function () {
}; };
this.setFrameDesign = function (newFrameDesign) { this.setFrameDesign = function (newFrameDesign) {
resetBuffers({ frame: true }); resetBuffers({frame: true});
frameDesign = newFrameDesign; frameDesign = newFrameDesign;
init({ frame: true }); init({frame: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setBackgroundColor = function (newBackgroundColor) { this.setBackgroundColor = function (newBackgroundColor) {
resetBuffers({ resetBuffers({background: true,
background: true, led: true});
led: true
});
backgroundColor = newBackgroundColor; backgroundColor = newBackgroundColor;
init({ init({background: true,
background: true, led: true});
led: true
});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setForegroundType = function (newForegroundType) { this.setForegroundType = function (newForegroundType) {
resetBuffers({ foreground: true }); resetBuffers({foreground: true});
foregroundType = newForegroundType; foregroundType = newForegroundType;
init({ foreground: true }); init({foreground: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setValueColor = function (newValueColor) { this.setValueColor = function (newValueColor) {
resetBuffers({ value: true }); resetBuffers({value: true});
valueColor = newValueColor; valueColor = newValueColor;
init({ value: true }); init({value: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setLedColor = function (newLedColor) { this.setLedColor = function (newLedColor) {
resetBuffers({ led: true }); resetBuffers({led: true});
ledColor = newLedColor; ledColor = newLedColor;
init({ led: true }); init({led: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setUserLedColor = function (newLedColor) { this.setUserLedColor = function (newLedColor) {
resetBuffers({ userLed: true }); resetBuffers({userLed: true});
userLedColor = newLedColor; userLedColor = newLedColor;
init({ userLed: true }); init({userLed: true});
this.repaint(); this.repaint();
return this; return this;
}; };
@ -2203,8 +2177,8 @@ var steelseries = (function () {
this.setLcdColor = function (newLcdColor) { this.setLcdColor = function (newLcdColor) {
lcdColor = newLcdColor; lcdColor = newLcdColor;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
@ -2245,8 +2219,8 @@ var steelseries = (function () {
this.setMinValue = function (value) { this.setMinValue = function (value) {
minValue = value; minValue = value;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
@ -2257,8 +2231,8 @@ var steelseries = (function () {
this.setMaxValue = function (value) { this.setMaxValue = function (value) {
maxValue = value; maxValue = value;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
@ -2271,8 +2245,8 @@ var steelseries = (function () {
newValue = parseFloat(newValue); newValue = parseFloat(newValue);
var targetValue = newValue < minValue ? minValue : (newValue > maxValue ? maxValue : newValue); var targetValue = newValue < minValue ? minValue : (newValue > maxValue ? maxValue : newValue);
threshold = targetValue; threshold = targetValue;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
@ -2288,16 +2262,16 @@ var steelseries = (function () {
this.setTitleString = function (title) { this.setTitleString = function (title) {
titleString = title; titleString = title;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setUnitString = function (unit) { this.setUnitString = function (unit) {
unitString = unit; unitString = unit;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
@ -2316,15 +2290,15 @@ var steelseries = (function () {
this.setFractionalScaleDecimals = function (decimals) { this.setFractionalScaleDecimals = function (decimals) {
fractionalScaleDecimals = parseInt(decimals, 10); fractionalScaleDecimals = parseInt(decimals, 10);
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
}; };
this.setLabelNumberFormat = function (format) { this.setLabelNumberFormat = function (format) {
labelNumberFormat = format; labelNumberFormat = format;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
@ -2339,15 +2313,13 @@ var steelseries = (function () {
fraction; fraction;
if (!initialized) { if (!initialized) {
init({ init({frame: true,
frame: true,
background: true, background: true,
led: true, led: true,
userLed: true, userLed: true,
value: true, value: true,
trend: true, trend: true,
foreground: true foreground: true});
});
} }
mainCtx.clearRect(0, 0, size, size); mainCtx.clearRect(0, 0, size, size);
@ -2666,7 +2638,7 @@ var steelseries = (function () {
lcdBuffer = createLcdBackgroundImage(width, height, lcdColor); lcdBuffer = createLcdBackgroundImage(width, height, lcdColor);
if (null !== section && 0 < section.length) { if (null !== section && 0 < section.length) {
for (sectionIndex = 0; sectionIndex < section.length; sectionIndex++) { for (sectionIndex = 0 ; sectionIndex < section.length ; sectionIndex++) {
sectionBuffer[sectionIndex] = createLcdSectionImage(width, height, section[sectionIndex].color, lcdColor); sectionBuffer[sectionIndex] = createLcdSectionImage(width, height, section[sectionIndex].color, lcdColor);
sectionForegroundColor[sectionIndex] = createSectionForegroundColor(section[sectionIndex].color); sectionForegroundColor[sectionIndex] = createSectionForegroundColor(section[sectionIndex].color);
} }
@ -2692,7 +2664,7 @@ var steelseries = (function () {
this.setSection = function (newSection) { this.setSection = function (newSection) {
section = newSection; section = newSection;
init({ background: true, foreground: true }); init({background: true, foreground: true});
this.repaint(); this.repaint();
return this; return this;
}; };
@ -2724,7 +2696,7 @@ var steelseries = (function () {
var sectionIndex; var sectionIndex;
// Draw sections // Draw sections
if (null !== section && 0 < section.length) { if (null !== section && 0 < section.length) {
for (sectionIndex = 0; sectionIndex < section.length; sectionIndex++) { for (sectionIndex = 0 ; sectionIndex < section.length ; sectionIndex++) {
if (value >= section[sectionIndex].start && value <= section[sectionIndex].stop) { if (value >= section[sectionIndex].start && value <= section[sectionIndex].stop) {
lcdBackgroundBuffer = sectionBuffer[sectionIndex]; lcdBackgroundBuffer = sectionBuffer[sectionIndex];
lcdTextColor = sectionForegroundColor[sectionIndex]; lcdTextColor = sectionForegroundColor[sectionIndex];
@ -2827,7 +2799,7 @@ var steelseries = (function () {
// Buffer for LCD displays // Buffer for LCD displays
var lcdBuffer; var lcdBuffer;
// Buffer for latest pointer /images painting code // Buffer for latest pointer images painting code
var pointerBufferLatest = createBuffer(size, size); var pointerBufferLatest = createBuffer(size, size);
var pointerContextLatest = pointerBufferLatest.getContext('2d'); var pointerContextLatest = pointerBufferLatest.getContext('2d');
@ -3327,7 +3299,7 @@ var steelseries = (function () {
requestAnimFrame(gauge.repaint); requestAnimFrame(gauge.repaint);
} }
// do we have a callback function to process? // do we have a callback function to process?
if (callback && typeof (callback) === "function") { if (callback && typeof(callback) === "function") {
callback(); callback();
} }
}; };
@ -3379,7 +3351,7 @@ var steelseries = (function () {
requestAnimFrame(gauge.repaint); requestAnimFrame(gauge.repaint);
} }
// do we have a callback function to process? // do we have a callback function to process?
if (callback && typeof (callback) === "function") { if (callback && typeof(callback) === "function") {
callback(); callback();
} }
}; };
@ -3399,68 +3371,66 @@ var steelseries = (function () {
this.setArea = function (areaVal) { this.setArea = function (areaVal) {
area = areaVal; area = areaVal;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setSection = function (areaSec) { this.setSection = function (areaSec) {
section = areaSec; section = areaSec;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setFrameDesign = function (newFrameDesign) { this.setFrameDesign = function (newFrameDesign) {
frameDesign = newFrameDesign; frameDesign = newFrameDesign;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setBackgroundColor = function (newBackgroundColor) { this.setBackgroundColor = function (newBackgroundColor) {
backgroundColor = newBackgroundColor; backgroundColor = newBackgroundColor;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setForegroundType = function (newForegroundType) { this.setForegroundType = function (newForegroundType) {
resetBuffers({ foreground: true }); resetBuffers({foreground: true});
foregroundType = newForegroundType; foregroundType = newForegroundType;
init({ foreground: true }); init({foreground: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setPointerColor = function (newPointerColor) { this.setPointerColor = function (newPointerColor) {
resetBuffers({ pointer: true }); resetBuffers({pointer: true});
pointerColor = newPointerColor; pointerColor = newPointerColor;
init({ pointer: true }); init({pointer: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setPointerColorAverage = function (newPointerColor) { this.setPointerColorAverage = function (newPointerColor) {
resetBuffers({ pointer: true }); resetBuffers({pointer: true});
pointerColorAverage = newPointerColor; pointerColorAverage = newPointerColor;
init({ pointer: true }); init({pointer: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setPointerType = function (newPointerType) { this.setPointerType = function (newPointerType) {
pointerTypeLatest = newPointerType; pointerTypeLatest = newPointerType;
resetBuffers({ resetBuffers({pointer: true,
pointer: true,
foreground: true foreground: true
}); });
init({ init({pointer: true,
pointer: true,
foreground: true foreground: true
}); });
this.repaint(); this.repaint();
@ -3469,12 +3439,10 @@ var steelseries = (function () {
this.setPointerTypeAverage = function (newPointerType) { this.setPointerTypeAverage = function (newPointerType) {
pointerTypeAverage = newPointerType; pointerTypeAverage = newPointerType;
resetBuffers({ resetBuffers({pointer: true,
pointer: true,
foreground: true foreground: true
}); });
init({ init({pointer: true,
pointer: true,
foreground: true foreground: true
}); });
this.repaint(); this.repaint();
@ -3483,37 +3451,35 @@ var steelseries = (function () {
this.setPointSymbols = function (newPointSymbols) { this.setPointSymbols = function (newPointSymbols) {
pointSymbols = newPointSymbols; pointSymbols = newPointSymbols;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setLcdColor = function (newLcdColor) { this.setLcdColor = function (newLcdColor) {
lcdColor = newLcdColor; lcdColor = newLcdColor;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.setLcdTitleStrings = function (titles) { this.setLcdTitleStrings = function (titles) {
lcdTitleStrings = titles; lcdTitleStrings = titles;
resetBuffers({ background: true }); resetBuffers({background: true});
init({ background: true }); init({background: true});
this.repaint(); this.repaint();
return this; return this;
}; };
this.repaint = function () { this.repaint = function () {
if (!initialized) { if (!initialized) {
init({ init({frame: true,
frame: true,
background: true, background: true,
led: true, led: true,
pointer: true, pointer: true,
foreground: true foreground: true});
});
} }
mainCtx.clearRect(0, 0, mainCtx.canvas.width, mainCtx.canvas.height); mainCtx.clearRect(0, 0, mainCtx.canvas.width, mainCtx.canvas.height);
@ -3874,7 +3840,7 @@ var steelseries = (function () {
}; };
// do we have a callback function to process? // do we have a callback function to process?
if (callback && typeof (callback) === "function") { if (callback && typeof(callback) === "function") {
tween.onMotionFinished = callback; tween.onMotionFinished = callback;
} }
@ -3945,7 +3911,7 @@ var steelseries = (function () {
ctx.translate(-centerX, -centerY); ctx.translate(-centerX, -centerY);
/* /*
// PATH1_2 // PATH1_2
ctx.save(); ctx.save();
ctx.beginPath(); ctx.beginPath();
@ -4089,7 +4055,7 @@ var steelseries = (function () {
ctx.fill(); ctx.fill();
ctx.stroke(); ctx.stroke();
ctx.restore(); ctx.restore();
*/ */
// Replacement code, not quite the same but much smaller! // Replacement code, not quite the same but much smaller!
for (i = 0; 360 >= i; i += 90) { for (i = 0; 360 >= i; i += 90) {
@ -4659,7 +4625,7 @@ var steelseries = (function () {
0.875, 0.875,
1]; 1];
colors = [new RgbaColor(254, 254, 254, 1), colors = [ new RgbaColor(254, 254, 254, 1),
new RgbaColor(0, 0, 0, 1), new RgbaColor(0, 0, 0, 1),
new RgbaColor(153, 153, 153, 1), new RgbaColor(153, 153, 153, 1),
new RgbaColor(0, 0, 0, 1), new RgbaColor(0, 0, 0, 1),
@ -4696,7 +4662,7 @@ var steelseries = (function () {
0.875, 0.875,
1]; 1];
colors = [new RgbaColor(254, 254, 254, 1), colors = [ new RgbaColor(254, 254, 254, 1),
new RgbaColor(210, 210, 210, 1), new RgbaColor(210, 210, 210, 1),
new RgbaColor(179, 179, 179, 1), new RgbaColor(179, 179, 179, 1),
new RgbaColor(238, 238, 238, 1), new RgbaColor(238, 238, 238, 1),
@ -4743,7 +4709,7 @@ var steelseries = (function () {
0.97, 0.97,
1]; 1];
colors = [new RgbaColor(255, 255, 255, 1), colors = [ new RgbaColor(255, 255, 255, 1),
new RgbaColor(255, 255, 255, 1), new RgbaColor(255, 255, 255, 1),
new RgbaColor(136, 136, 138, 1), new RgbaColor(136, 136, 138, 1),
new RgbaColor(164, 185, 190, 1), new RgbaColor(164, 185, 190, 1),
@ -4911,7 +4877,7 @@ var steelseries = (function () {
radBCtx.lineWidth = 0.5; radBCtx.lineWidth = 0.5;
end = TWO_PI - stepSize * 0.3; end = TWO_PI - stepSize * 0.3;
// Step the engine round'n'round // Step the engine round'n'round
for (i = 0; i < end; i += stepSize) { for (i = 0 ; i < end; i += stepSize) {
// draw a 'turn' // draw a 'turn'
radBCtx.strokeStyle = 'rgba(240, 240, 255, 0.25)'; radBCtx.strokeStyle = 'rgba(240, 240, 255, 0.25)';
radBCtx.beginPath(); radBCtx.beginPath();
@ -6033,7 +5999,7 @@ var steelseries = (function () {
if (radius !== 0) { if (radius !== 0) {
totR = totG = totB = 0; totR = totG = totB = 0;
} }
for (x = 0; x < width; x++) { for (x = 0; x < width; x ++) {
indx = (y * width * 4) + (x * 4); indx = (y * width * 4) + (x * 4);
tr = red; tr = red;
tg = green; tg = green;
@ -6090,7 +6056,7 @@ var steelseries = (function () {
indx = 0; indx = 0;
for (y = 0; y < height; y++) { for (y = 0; y < height; y++) {
totR = totG = totB = 0; totR = totG = totB = 0;
for (x = 0; x < radius; x++) { for (x = 0; x < radius ; x++) {
i = (indx + x) * 4; i = (indx + x) * 4;
totR += inPix.data[i]; totR += inPix.data[i];
totG += inPix.data[i + 1]; totG += inPix.data[i + 1];
@ -6208,8 +6174,8 @@ var steelseries = (function () {
indx, pixColor, indx, pixColor,
buffer, bufferCtx; buffer, bufferCtx;
// Original Version using rotated lines // Original Version using rotated lines
/* /*
ctx.save(); ctx.save();
ctx.lineWidth = 1.5; ctx.lineWidth = 1.5;
ctx.translate(centerX, centerY); ctx.translate(centerX, centerY);
@ -6235,8 +6201,8 @@ var steelseries = (function () {
ctx.stroke(); ctx.stroke();
} }
} }
*/ */
// End - Original Version // End - Original Version
// Create pixel array // Create pixel array
pixels = ctx.createImageData(diameter, diameter); pixels = ctx.createImageData(diameter, diameter);
@ -6404,11 +6370,9 @@ var steelseries = (function () {
} }
function section(start, stop, color) { function section(start, stop, color) {
return { return {start : start,
start: start, stop : stop,
stop: stop, color : color};
color: color
};
} }
Math.log10 = function (value) { Math.log10 = function (value) {
@ -6458,7 +6422,7 @@ var steelseries = (function () {
ctx.lineTo(x, y + radius); ctx.lineTo(x, y + radius);
ctx.quadraticCurveTo(x, y, x + radius, y); ctx.quadraticCurveTo(x, y, x + radius, y);
ctx.closePath(); ctx.closePath();
// ctx.stroke(); // ctx.stroke();
} }
function createBuffer(width, height) { function createBuffer(width, height) {
@ -6969,42 +6933,42 @@ var steelseries = (function () {
//********************************** E X P O R T F U N C T I O N S ******************************************* //********************************** E X P O R T F U N C T I O N S *******************************************
return { return {
// Components EXTERNAL : INTERNAL // Components EXTERNAL : INTERNAL
Radial: radial, Radial : radial,
RadialBargraph: radialBargraph, RadialBargraph : radialBargraph,
DisplaySingle: displaySingle, DisplaySingle: displaySingle,
WindDirection: windDirection, WindDirection : windDirection,
Led: led, Led : led,
Odometer: odometer, Odometer: odometer,
// /images // Images
drawFrame: drawRadialFrameImage, drawFrame : drawRadialFrameImage,
drawBackground: drawRadialBackgroundImage, drawBackground : drawRadialBackgroundImage,
drawForeground: drawRadialForegroundImage, drawForeground : drawRadialForegroundImage,
// Tools // Tools
rgbaColor: RgbaColor, rgbaColor : RgbaColor,
ConicalGradient: ConicalGradient, ConicalGradient : ConicalGradient,
setAlpha: setAlpha, setAlpha : setAlpha,
getColorFromFraction: getColorFromFraction, getColorFromFraction : getColorFromFraction,
gradientWrapper: GradientWrapper, gradientWrapper : GradientWrapper,
// Constants // Constants
BackgroundColor: backgroundColor, BackgroundColor : backgroundColor,
LcdColor: lcdColor, LcdColor : lcdColor,
ColorDef: color, ColorDef : color,
LedColor: ledColor, LedColor : ledColor,
GaugeType: gaugeType, GaugeType : gaugeType,
Orientation: orientation, Orientation: orientation,
FrameDesign: frameDesign, FrameDesign : frameDesign,
PointerType: pointerType, PointerType : pointerType,
ForegroundType: foregroundType, ForegroundType : foregroundType,
KnobType: knobType, KnobType : knobType,
KnobStyle: knobStyle, KnobStyle: knobStyle,
LabelNumberFormat: labelNumberFormat, LabelNumberFormat: labelNumberFormat,
TickLabelOrientation: tickLabelOrientation, TickLabelOrientation: tickLabelOrientation,
TrendState: trendState, TrendState: trendState,
// Other // Other
Section: section Section : section
}; };
}()); }());

242
oldindex.htm Normal file
View file

@ -0,0 +1,242 @@
<div id="Header" class="w3-row w3-top w3-theme-dark w3-theme-bdr">
<div class="w3-row-padding site-width">
<div class="at-flex-between" style="align-items:center; flex-wrap:wrap;">
<img src="images/CumulusMX-Logo.png" class="w3-image logo" alt="Header logo" />
<div class="w3-right-align" style="max-width:600px;">
<h5>Lat<span class="w3-hide-small">itude</span>:&nbsp;<span data-cmxdata="latitude"></span><span
class="at-divider">|<wbr></span>Long<span class="w3-hide-small">itude</span>:&nbsp;<span
data-cmxdata="longitude"></span><span class="at-divider">|<wbr></span>Alt<span
class="w3-hide-small">itude</span>:&nbsp;<span data-cmxdata="altitude"></span></h5>
</div>
</div>
<!-- Start of Menu -->
<div id="Main_Menu" class="w3-bar w3-theme-d4 w3-theme-bdr">
</div>
<!-- Mobile menu -->
<div id="Main_Menu_Mobile" class="w3-bar-block w3-hide w3-hide-large">
</div> <!-- End of Mobile menu -->
</div>
</div>
<div id="Content">
<!-- Start of panel content -->
<div class="w3-row-padding w3-theme-light site-width">
<!-- Page Title -->
<div class="w3-col l12">
<h1><span data-cmxdata="location"></span> Weather <span class="subText"></span></h1>
</div>
</div> <!-- End of title row -->
<div class="w3-row site-width w3-theme-light">
<!-- Start of Main panel -->
<div class="w3-col l9 m12">
<!-- 3/4 width panel -->
<div class="w3-row-padding">
<!-- Row 1 of 3/4 width panel -->
<div class="w3-col s12">
<!-- Full width of above panel -->
<div class="w3-panel w3-container w3-theme-white">
<h3 class="">Almanac</h3>
<div class="w3-responsive">
<table class="w3-table" style="min-width:100%;">
<tbody>
<tr>
<td class="">Dawn:</td>
<td class=""><span data-cmxdata="dawn"></span></td>
<td class="">Sun Rise:</td>
<td class=""><span data-cmxdata="sunrise"></span></td>
<td class="">Moon Rise:</td>
<td class=""><span data-cmxdata="moonrise"></span></td>
<td rowspan="3" style="width:75px; height: 75px; padding:0"><img id="moonImg"
src="images/moon.png" alt="Moon" width="75" height="75"
class="w3-image" />Visible <span data-cmxdata="MoonPercentAbs"></span>%
</td>
</tr>
<tr>
<td class="">Dusk:</td>
<td class=""><span data-cmxdata="dusk"></span></td>
<td class="">Sun Set:</td>
<td class=""><span data-cmxdata="sunset"></span></td>
<td class="">Moon Set:</td>
<td class=""><span data-cmxdata="moonset"></span></td>
</tr>
<tr>
<td class="">Daylight:</td>
<td class=""><span data-cmxdata="daylightlength"></span></td>
<td class="">Day Length:</td>
<td class=""><span data-cmxdata="daylength"></span></td>
<td class="">Moon Phase:</td>
<td class=""><span id="moonPhase" data-cmxdata="moonphase"></span></td>
</tr>
<tr id="currCond" class="w3-hide">
<td colspan="7"><strong>Current conditions</strong>: <span
data-cmxdata="currcond"></span></td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</div>
<div class="w3-row-padding">
<!-- Row 2 of 3/4 width panel -->
<div class="w3-col s12">
<!-- Full width of above panel -->
<div class="w3-panel w3-card w3-theme-white">
<h3 class="">Conditions at local time <span data-cmxdata="time"></span></h3>
<div class="w3-responsive">
<table class="w3-table w3-hoverable" style="min-width:100%;">
<tr>
<td colspan="4" class="w3-theme-d5">Temperature and Humidity</td>
</tr>
<tr class="w3-theme-l2">
<td>Temperature</td>
<td><span data-cmxdata="temp"></span>&nbsp;<span data-cmxdata="tempunit"></span>
</td>
<td>Dew Point</td>
<td><span data-cmxdata="dew"></span>&nbsp;<span data-cmxdata="tempunit"></span>
</td>
</tr>
<tr class="w3-theme-l2">
<td>Windchill</td>
<td><span data-cmxdata="wchill"></span>&nbsp;<span data-cmxdata="tempunit"></span>
</td>
<td>Humidity</td>
<td><span data-cmxdata="hum"></span>&nbsp;%</td>
</tr>
<tr class="w3-theme-l2">
<td>Heat Index</td>
<td><span data-cmxdata="heatindex"></span>&nbsp;<span
data-cmxdata="tempunit"></span></td>
<td><span data-cmx-apparent class="w3-hide">Apparent Temperature</span><span
data-cmx-feels>Feels Like</span></td>
<td><span data-cmx-apparent data-cmxdata="apptemp" class="w3-hide"></span><span
data-cmx-feels data-cmxdata="feelslike"></span>&nbsp;<span
data-cmxdata="tempunit"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>Temp change last hour</td>
<td><span data-cmxdata="TempChangeLastHour"></span>&nbsp;<span
data-cmxdata="tempunit"></span></td>
<td></td>
<td></td>
</tr>
<tr>
<td colspan="4" class="w3-theme-d4">Rainfall</td>
</tr>
<tr class="w3-theme-l3">
<td>Rainfall Today</td>
<td><span data-cmxdata="rfall"></span>&nbsp;<span data-cmxdata="rainunit"></span>
</td>
<td>Rainfall Rate</td>
<td><span data-cmxdata="rrate"></span>&nbsp;<span data-cmxdata="rainunit"></span>/hr
</td>
</tr>
<tr class="w3-theme-l3">
<td>Rainfall This Month</td>
<td><span data-cmxdata="rmonth"></span>&nbsp;<span data-cmxdata="rainunit"></span>
</td>
<td>Rainfall This Year</td>
<td><span data-cmxdata="ryear"></span>&nbsp;<span data-cmxdata="rainunit"></span>
</td>
</tr>
<tr class="w3-theme-l3">
<td>Rainfall Last Hour</td>
<td><span data-cmxdata="rhour"></span>&nbsp;<span data-cmxdata="rainunit"></span>
</td>
<td>Last rainfall</td>
<td><span data-cmxdata="LastRainTip"></span></td>
</tr>
<tr class="w3-theme-l3">
<td>Rainfall Since Midnight</td>
<td><span data-cmxdata="rmidnight"></span>&nbsp;<span
data-cmxdata="rainunit"></span></td>
<td>Rainfall Last 24 Hours</td>
<td><span data-cmxdata="r24hour"></span>&nbsp;<span data-cmxdata="rainunit"></span>
</td>
</tr>
<tr>
<td colspan="4" class="w3-theme-d3">Wind</td>
</tr>
<tr class="w3-theme-l4">
<td>Wind Speed <span class="subText">(gust)</span></td>
<td><span data-cmxdata="wgust"></span>&nbsp;<span data-cmxdata="windunit"></span>
</td>
<td>Wind Speed <span class="subText">(avg)</span></td>
<td><span data-cmxdata="wspeed"></span>&nbsp;<span data-cmxdata="windunit"></span>
</td>
</tr>
<tr class="w3-theme-l4">
<td>Wind Bearing</td>
<td><span data-cmxdata="avgbearing"></span>&deg; <span data-cmxdata="wdir"></span>
</td>
<td>Beaufort <span data-cmxdata="beaufort"></span></td>
<td><span data-cmxdata="beaudesc"></span></td>
</tr>
<tr class="w3-theme-l4">
<td>Wind Variation <span class="subText">(last 10 minutes)</span></td>
<td colspan="3">From <span data-cmxdata="BearingRangeFrom"></span>&deg; to <span
data-cmxdata="BearingRangeTo"></span>&deg;</td>
</tr>
<tr>
<td colspan="4" class="w3-theme-d2">Pressure <span class="subText">(sea
level)</span></td>
</tr>
<tr class="w3-theme-l5">
<td>Barometer</td>
<td><span data-cmxdata="press"></span>&nbsp;<span data-cmxdata="pressunit"></span>
</td>
<td><span data-cmxdata="presstrend"></span></td>
<td><span data-cmxdata="presstrendval"></span>&nbsp;<span
data-cmxdata="pressunit"></span>/hr</td>
</tr>
<tr class="w3-hide" data-cmx-solar data-cmx-uv>
<td colspan="4" class="w3-theme-d1">Solar</td>
</tr>
<tr class="w3-theme-l6 w3-hide" data-cmx-solar>
<td>Solar Radiation</td>
<td><span data-cmxdata="SolarRad"></span>&nbsp;W/m&sup2;</td>
<td>Evapotranspiration Today</td>
<td><span data-cmxdata="ET"></span>&nbsp;<span data-cmxdata="rainunit"></span>
</td>
</tr>
<tr class="w3-theme-l6 w3-hide" data-cmx-uv>
<td>UV Index</td>
<td><span data-cmxdata="UV"></span></td>
<td></td>
<td></td>
</tr>
</table>
</div>
<p class="w3-small credits">Page updated <span data-cmxdata="update"></span>.</p>
</div>
</div>
</div>
</div>
<div class="w3-col l3 m12">
<!-- Start of Sidebar 1/4 width -->
<div class="w3-row-padding">
<div class="w3-col l12">
<div class="w3-panel w3-container w3-theme-light">
<h3 class="w3-center">Welcome to <br /><span class="subText"><span
data-cmxdata="longlocation"></span></span></h3>
<p>The weather station in use is the <span data-cmxdata="stationtype"></span><br>
This page is updated every <span data-cmxdata="interval"></span> minutes. The
meteorological day used at this station ends at <span data-cmxdata="rollovertime"></span>.
</p>
<p><strong>Forecast:</strong> <span data-cmxdata="forecast"></span></p>
</div>
</div>
</div>
</div>
</div> <!-- End of panel content -->
</div> <!-- End of content -->
<div id="Footer" class="w3-row w3-bottom w3-theme-dark w3-theme-bdr">
<div class="w3-row-padding site-width">
<p><em>Cumulus MX Template by Neil Thomas
<script>
document.write(new Date().getFullYear());
</script>
<span class="w3-right">Powered by <span class="w3-theme-txt">Cumulus MX</span> v:<span
data-cmxdata="version"></span>, b:<span data-cmxdata="build"></span></span>
</em></p>
</div>
</div>

239
today.htm Normal file
View file

@ -0,0 +1,239 @@
<!--
today.htm v:0.0.1 d:Feb 2021 Neil Thomas
Last modified: 2022/07/27 10:11:12
Page: 1 main panel plus a sidebar
-->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="description" content="weather data">
<meta name="keywords" content="Cumulus, weather, data, weather station">
<title>Cumulus MX</title>
<link rel="icon" type="image/png" href="images/favicon.png">
<!-- jQuery Local -->
<script src="lib/jquery/jquery-latest.min.js"></script>
<!-- Fonts System will default to a sans-serif font if no Internet connection -->
<link rel="preconnect" href="https://fonts.gstatic.com">
<link href="https://fonts.googleapis.com/css2?family=Rosario:ital,wght@0,400;0,500;0,600;1,400;1,500;1,600&display=swap" rel="stylesheet">
<!-- All Styles -->
<link href="css/w3Pro.css" rel="stylesheet"> <!-- Basic w3shools responsive styles -->
<link href="css/colours.css" rel="stylesheet"> <!-- Slightly enhanced w3schools colours -->
<link href="css/mx-templates.css" rel="stylesheet"> <!-- Specific styles for these templates. -->
<!-- Scripts -->
<script src="js/setpagedata.js"></script> <!-- Utility javascripts for all pages. -->
</head>
<body>
<div id="Header" class="w3-row w3-top w3-theme-dark w3-theme-bdr">
<div class="w3-row-padding site-width">
<div class="at-flex-between" style="align-items:center; flex-wrap:wrap;">
<img src="images/CumulusMX-Logo.png" class="w3-image logo" alt="Header logo"/>
<div class="w3-right-align" style="max-width:600px;">
<h5>Lat<span class="w3-hide-small">itude</span>:&nbsp;<span data-cmxdata="latitude"></span><span class="at-divider">|<wbr></span>Long<span class="w3-hide-small">itude</span>:&nbsp;<span data-cmxdata="longitude"></span><span class="at-divider">|<wbr></span>Alt<span class="w3-hide-small">itude</span>:&nbsp;<span data-cmxdata="altitude"></span></h5>
</div>
</div>
<!-- Start of Menu -->
<div id="Main_Menu" class="w3-bar w3-theme-d4 w3-theme-bdr">
</div>
<!-- Mobile menu -->
<div id="Main_Menu_Mobile" class="w3-bar-block w3-hide w3-hide-large">
</div> <!-- End of Mobile menu -->
</div>
</div>
<div id="Content"> <!-- Start of panel content -->
<div class="w3-row-padding w3-theme-light site-width"> <!-- Page Title -->
<div class="w3-col l12">
<h1>Today <span class="subText"><span data-cmxdata="date"></span></span></h1>
</div>
</div> <!-- End of title row -->
<div class="w3-row site-width w3-theme-light"> <!-- Start of Main panel -->
<div class="w3-col l9 m12"> <!-- 3/4 width panel -->
<div class="w3-row-padding"> <!-- Row 1 of 3/4 width panel -->
<div class="w3-col s12"> <!-- Full width of above panel -->
<div class="w3-panel w3-card w3-theme-white">
<h2>Today&#39;s data</h2>
<div class="w3-responsive">
<table class="w3-table w3-hoverable" style="width:100%">
<tbody>
<tr class="w3-theme-d5">
<td colspan="3">Temperature and Humidity</td>
</tr>
<tr class="w3-theme-l2">
<td>High Temperature</td>
<td><span data-cmxdata="tempTH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TtempTH"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>Low Temperature</td>
<td><span data-cmxdata="tempTL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TtempTL"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>Temperature Range</td>
<td><span data-cmxdata="temprange"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td></td>
</tr>
<tr data-cmx-apparent class="w3-theme-l2 w3-hide">
<td>High Apparent Temperature</td>
<td><span data-cmxdata="apptempTH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TapptempTH"></span></td>
</tr>
<tr data-cmx-apparent class="w3-theme-l2 w3-hide">
<td>Low Apparent Temperature</td>
<td><span data-cmxdata="apptempTL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TapptempTL"></span></td>
</tr>
<tr data-cmx-feels class="w3-theme-l2">
<td>High Feels Like</td>
<td><span data-cmxdata="feelslikeTH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TfeelslikeTH"></span></td>
</tr>
<tr data-cmx-feels class="w3-theme-l2">
<td>Low Feels Like</td>
<td><span data-cmxdata="feelslikeTL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TfeelslikeTL"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>Low Wind Chill</td>
<td><span data-cmxdata="wchillTL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TwchillTL"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>High Heat Index</td>
<td><span data-cmxdata="heatindexTH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TheatindexTH"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>High Humidity</td>
<td><span data-cmxdata="humTH"></span> %</td>
<td>at <span data-cmxdata="ThumTH"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>Low Humidity</td>
<td><span data-cmxdata="humTL"></span> %</td>
<td>at <span data-cmxdata="ThumTL"></span></td>
</tr>
<tr class="w3-theme-d4">
<td colspan="3">Rainfall</td>
</tr>
<tr class="w3-theme-l3">
<td>Rainfall Today</td>
<td><span data-cmxdata="rfall"></span>&nbsp;<span data-cmxdata="rainunit"></span></td>
<td></td>
</tr>
<tr class="w3-theme-l3">
<td>Rainfall Rate Max</td>
<td><span data-cmxdata="rrateTM"></span>&nbsp;<span data-cmxdata="rainunit"></span>/hr</td>
<td>at <span data-cmxdata="TrrateTM"></span></td>
</tr>
<tr class="w3-theme-l3">
<td>High Hourly Rainfall</td>
<td><span data-cmxdata="hourlyrainTH"></span>&nbsp;<span data-cmxdata="rainunit"></span></td>
<td>at <span data-cmxdata="ThourlyrainTH"></span></td>
</tr>
<tr class="w3-theme-l3">
<td>High 24 Hour Rainfall</td>
<td><span data-cmxdata="rain24hourTH"></span>&nbsp;<span data-cmxdata="rainunit"></span></td>
<td>at <span data-cmxdata="Train24hourTH"></span></td>
</tr>
<tr class="w3-theme-l3">
<td>Days Since Last Dry Day</td>
<td><span data-cmxdata="ConsecutiveRainDays"></span></td>
<td></td>
</tr>
<tr class="w3-theme-l3">
<td>Days Since It Last Rained</td>
<td><span data-cmxdata="ConsecutiveDryDays"></span></td>
<td></td>
</tr>
<tr class="w3-theme-d3">
<td colspan="3">Wind</td>
</tr>
<tr class="w3-theme-l4">
<td>High Gust</td>
<td><span data-cmxdata="wgustTM"></span>&nbsp;<span data-cmxdata="windunit"></span></td>
<td>at <span data-cmxdata="TwgustTM"></span></td>
</tr>
<tr class="w3-theme-l4">
<td>High Speed <span class="subText">(10 minute average)</span></td>
<td><span data-cmxdata="windTM"></span>&nbsp;<span data-cmxdata="windunit"></span> (<span data-cmxdata="Tbeaufort"></span>)</td>
<td>at <span data-cmxdata="TwindTM"></span></td>
</tr>
<tr class="w3-theme-l4">
<td>Wind Run</td>
<td><span data-cmxdata="windrun"></span>&nbsp;<span data-cmxdata="windrununit"></span></td>
<td></td>
</tr>
<tr class="w3-theme-l4">
<td>Dominant Direction</td>
<td><span data-cmxdata="domwindbearing"></span>&deg; <span data-cmxdata="domwinddir"></span></td>
<td></td>
</tr>
<tr class="w3-theme-d2">
<td colspan="3">Pressure <span class="subText">(sea level)</span></td>
</tr>
<tr class="w3-theme-l5">
<td>High Pressure</td>
<td><span data-cmxdata="pressTH"></span>&nbsp;<span data-cmxdata="pressunit"></span></td>
<td>at <span data-cmxdata="TpressTH"></span></td>
</tr>
<tr class="w3-theme-l5">
<td>Low Pressure</td>
<td><span data-cmxdata="pressTL"></span>&nbsp;<span data-cmxdata="pressunit"></span></td>
<td>at <span data-cmxdata="TpressTL"></span></td>
</tr>
<tr class="w3-theme-d1 w3-hide" data-cmx-solar data-cmx-uv>
<td colspan="3" class="w3-theme-d1">Solar</td>
</tr>
<tr class="w3-theme-l6 w3-hide" data-cmx-solar>
<td>High Solar Radiation</td>
<td><span data-cmxdata="solarTH"></span> W/m<sup>2</sup></td>
<td>at <span data-cmxdata="TsolarTH"></span></td>
</tr>
<tr class="w3-theme-l6 w3-hide" data-cmx-solar>
<td>Hours of Sunshine</td>
<td><span data-cmxdata="SunshineHours"></span> hrs</td>
<td></td>
</tr>
<tr class="w3-theme-l6 w3-hide" data-cmx-uv>
<td>High UV Index</td>
<td><span data-cmxdata="UVTH"></span></td>
<td>at <span data-cmxdata="TUVTH"></span></td>
</tr>
</tbody>
</table>
<p class="w3-small">Page data updated <span data-cmxdata="update"></span>.</p>
</div>
</div>
</div>
</div>
</div>
<div class="w3-col l3 m12"> <!-- Start of Sidebar 1/4 screen width -->
<div class="w3-row-padding">
<div class="w3-col l12"> <!-- Full width of sidebar -->
<div class="w3-panel w3-container w3-theme-light">
<h3 class="w3-center">Welcome to <br/><span class="subText"><span data-cmxdata="longlocation"></span></span></h3>
<p>This page shows the highs, lows and current values for today.<br>
This page is updated every <span data-cmxdata="interval"></span> minutes. The meteorological day used at this station ends at
<span data-cmxdata="rollovertime"></span>.
</p>
</div>
</div>
</div>
</div>
</div> <!-- End of panel content -->
</div> <!-- End of content -->
<!-- Footer -->
<div id="Footer" class="w3-row w3-bottom w3-theme-dark w3-theme-bdr">
<div class="w3-row-padding site-width">
<p><em>Cumulus MX Template by Neil Thomas <script>document.write(new Date().getFullYear());</script>
<span class="w3-right">Powered by <span class="w3-theme-txt">Cumulus MX</span> v:<span data-cmxdata="version"></span>, b:<span data-cmxdata="build"></span></span></em></p>
</div>
</div>
</body>
</html>

View file

@ -1,148 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<?php include("../includes/head.inc.php"); ?>
<script>
window.onload = () => {
$('#moonImg').attr('src', '/images/moon.png?' + Date.now());
// update the moon image every 20 minutes if the page is left open
setInterval(() => {
$('#moonImg').attr('src', '/images/moon.png?' + Date.now());
}, 1200000);
};
</script>
</head>
<body>
<div class="page-container">
<?php include("../includes/header.inc.php"); ?>
<div id="content">
<h3>Data for today (<span data-cmxdata="date"></span>)</h3>
<table class="mx-datatable">
<tr>
<th colspan="4">Temperature and Humidity</th>
</tr>
<tr>
<td>High Temperature</td>
<td><span data-cmxdata="tempTH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TtempTH"></span></td>
</tr>
<tr>
<td>Low Temperature</td>
<td><span data-cmxdata="tempTL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TtempTL"></span></td>
</tr>
<tr>
<td>Temperature Range</td>
<td><span data-cmxdata="temprange"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td></td>
</tr>
<tr data-cmx-feels>
<td>High Feels Like</td>
<td><span data-cmxdata="feelslikeTH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TfeelslikeTH"></span></td>
</tr>
<tr data-cmx-feels>
<td>Low Feels Like</td>
<td><span data-cmxdata="feelslikeTL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TfeelslikeTL"></span></td>
</tr>
<tr>
<td>Low Wind Chill</td>
<td><span data-cmxdata="wchillTL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TwchillTL"></span></td>
</tr>
<tr>
<td>High Heat Index</td>
<td><span data-cmxdata="heatindexTH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TheatindexTH"></span></td>
</tr>
<tr>
<td>High Humidity</td>
<td><span data-cmxdata="humTH"></span> %</td>
<td>at <span data-cmxdata="ThumTH"></span></td>
</tr>
<tr>
<td>Low Humidity</td>
<td><span data-cmxdata="humTL"></span> %</td>
<td>at <span data-cmxdata="ThumTL"></span></td>
</tr>
<tr>
<th colspan="4">Rainfall</th>
</tr>
<tr>
<td>Rainfall Today</td>
<td><span data-cmxdata="rfall"></span>&nbsp;<span data-cmxdata="rainunit"></span></td>
<td></td>
</tr>
<tr>
<td>Rainfall Rate Max</td>
<td><span data-cmxdata="rrateTM"></span>&nbsp;<span data-cmxdata="rainunit"></span>/hr</td>
<td>at <span data-cmxdata="TrrateTM"></span></td>
</tr>
<tr>
<td>High Hourly Rainfall</td>
<td><span data-cmxdata="hourlyrainTH"></span>&nbsp;<span data-cmxdata="rainunit"></span></td>
<td>at <span data-cmxdata="ThourlyrainTH"></span></td>
</tr>
<tr>
<td>High 24 Hour Rainfall</td>
<td><span data-cmxdata="rain24hourTH"></span>&nbsp;<span data-cmxdata="rainunit"></span></td>
<td>at <span data-cmxdata="Train24hourTH"></span></td>
</tr>
<tr>
<td>Days Since Last Dry Day</td>
<td><span data-cmxdata="ConsecutiveRainDays"></span></td>
<td></td>
</tr>
<tr>
<td>Days Since It Last Rained</td>
<td><span data-cmxdata="ConsecutiveDryDays"></span></td>
<td></td>
</tr>
<tr>
<th colspan="4">Wind</th>
</tr>
<tr>
<td>High Gust</td>
<td><span data-cmxdata="wgustTM"></span>&nbsp;<span data-cmxdata="windunit"></span></td>
<td>at <span data-cmxdata="TwgustTM"></span></td>
</tr>
<tr>
<td>High Speed <span class="subText">(10 minute average)</span></td>
<td><span data-cmxdata="windTM"></span>&nbsp;<span data-cmxdata="windunit"></span> (<span
data-cmxdata="Tbeaufort"></span>)</td>
<td>at <span data-cmxdata="TwindTM"></span></td>
</tr>
<tr>
<td>Wind Run</td>
<td><span data-cmxdata="windrun"></span>&nbsp;<span data-cmxdata="windrununit"></span></td>
<td></td>
</tr>
<tr>
<td>Dominant Direction</td>
<td><span data-cmxdata="domwindbearing"></span>&deg; <span data-cmxdata="domwinddir"></span></td>
<td></td>
</tr>
<tr>
<th colspan="4">Pressure (sea level)</th>
</tr>
<tr>
<td>High Pressure</td>
<td><span data-cmxdata="pressTH"></span>&nbsp;<span data-cmxdata="pressunit"></span></td>
<td>at <span data-cmxdata="TpressTH"></span></td>
</tr>
<tr>
<td>Low Pressure</td>
<td><span data-cmxdata="pressTL"></span>&nbsp;<span data-cmxdata="pressunit"></span></td>
<td>at <span data-cmxdata="TpressTL"></span></td>
</tr>
</table>
<small>Page data updated <span data-cmxdata="update"></span></small>
</div>
<?php include("../includes/footer.inc.php"); ?>
</div>
</body>
</html>

225
yesterday.htm Normal file
View file

@ -0,0 +1,225 @@
<!--
yesterday.htm v:0.0.1 d:Feb 2021 Neil Thomas
Last modified: 2022/07/27 10:10:28
Page: 1 main panel plus a sidebar
-->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="description" content="weather data">
<meta name="keywords" content="Cumulus, weather, data, weather station">
<title>Cumulus MX</title>
<link rel="icon" type="image/png" href="images/favicon.png">
<!-- jQuery Local -->
<script src="lib/jquery/jquery-latest.min.js"></script>
<!-- Fonts System will default to a sans-serif font if no Internet connection -->
<link rel="preconnect" href="https://fonts.gstatic.com">
<link href="https://fonts.googleapis.com/css2?family=Rosario:ital,wght@0,400;0,500;0,600;1,400;1,500;1,600&display=swap" rel="stylesheet">
<!-- All Styles -->
<link href="css/w3Pro.css" rel="stylesheet"> <!-- Basic w3shools responsive styles -->
<link href="css/colours.css" rel="stylesheet"> <!-- Slightly enhanced w3schools colours -->
<link href="css/mx-templates.css" rel="stylesheet"> <!-- Specific styles for these templates. -->
<!-- Scripts -->
<script src="js/setpagedata.js"></script> <!-- Utility javascripts for all pages. -->
</head>
<body>
<div id="Header" class="w3-row w3-top w3-theme-dark w3-theme-bdr">
<div class="w3-row-padding site-width">
<div class="at-flex-between" style="align-items:center; flex-wrap:wrap;">
<img src="images/CumulusMX-Logo.png" class="w3-image logo" alt="Header logo"/>
<div class="w3-right-align" style="max-width:600px;">
<h5>Lat<span class="w3-hide-small">itude</span>:&nbsp;<span data-cmxdata="latitude"></span><span class="at-divider">|<wbr></span>Long<span class="w3-hide-small">itude</span>:&nbsp;<span data-cmxdata="longitude"></span><span class="at-divider">|<wbr></span>Alt<span class="w3-hide-small">itude</span>:&nbsp;<span data-cmxdata="altitude"></span></h5>
</div>
</div>
<!-- Start of Menu -->
<div id="Main_Menu" class="w3-bar w3-theme-d4 w3-theme-bdr">
</div>
<!-- Mobile menu -->
<div id="Main_Menu_Mobile" class="w3-bar-block w3-hide w3-hide-large">
</div> <!-- End of Mobile menu -->
</div>
</div>
<div id="Content"> <!-- Start of panel content -->
<div class="w3-row-padding w3-theme-light site-width"> <!-- Page Title -->
<div class="w3-col l12">
<h1>Yesterday <span class="subText"><span data-cmxdata="yesterday"></span></span></h1>
</div>
</div> <!-- End of title row -->
<div class="w3-row site-width w3-theme-light"> <!-- Start of Main panel -->
<div class="w3-col l9 m12"> <!-- 3/4 width panel -->
<div class="w3-row-padding"> <!-- Row 1 of 3/4 width panel -->
<div class="w3-col s12"> <!-- Full width of above panel -->
<div class="w3-panel w3-card w3-theme-white">
<h2 class="">Yesterday's data</h2>
<div class="w3-responsive">
<table class="w3-table w3-hoverable" style="width:100%">
<tbody>
<tr class="w3-theme-d5">
<td colspan="3">Temperature and Humidity</td>
</tr>
<tr class="w3-theme-l2">
<td>High Temperature</td>
<td><span data-cmxdata="tempYH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TtempYH"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>Low Temperature</td>
<td><span data-cmxdata="tempYL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TtempYL"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>Temperature Range</td>
<td><span data-cmxdata="temprangeY"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td></td>
</tr>
<tr data-cmx-apparent class="w3-theme-l2 w3-hide">
<td>High Apparent Temperature</td>
<td><span data-cmxdata="apptempYH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TapptempYH"></span></td>
</tr>
<tr data-cmx-apparent class="w3-theme-l2 w3-hide">
<td>Low Apparent Temperature</td>
<td><span data-cmxdata="apptempYL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TapptempYL"></span></td>
</tr>
<tr data-cmx-feels class="w3-theme-l2">
<td>High Feels Like</td>
<td><span data-cmxdata="feelslikeYH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TfeelslikeYH"></span></td>
</tr>
<tr data-cmx-feels class="w3-theme-l2">
<td>Low Feels Like</td>
<td><span data-cmxdata="feelslikeYL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TfeelslikeYL"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>Low Wind Chill</td>
<td><span data-cmxdata="wchillYL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TwchillYL"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>High Heat Index</td>
<td><span data-cmxdata="heatindexYH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TheatindexYH"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>High Humidity</td>
<td><span data-cmxdata="humYH"></span>&nbsp;%</td>
<td>at <span data-cmxdata="ThumYH"></span></td>
</tr>
<tr class="w3-theme-l2">
<td>Low Humidity</td>
<td><span data-cmxdata="humYL"></span>&nbsp;%</td>
<td>at <span data-cmxdata="ThumYL"></span></td>
</tr>
<tr class="w3-theme-d4">
<td colspan="3">Rainfall</td>
</tr>
<tr class="w3-theme-l3">
<td>Rainfall Yesterday</td>
<td><span data-cmxdata="rfallY"></span>&nbsp;<span data-cmxdata="rainunit"></span></td>
<td></td>
</tr>
<tr class="w3-theme-l3">
<td>Rainfall Rate Max</td>
<td><span data-cmxdata="rrateYM"></span>&nbsp;<span data-cmxdata="rainunit"></span>/hr</td>
<td>at <span data-cmxdata="TrrateYM"></span></td>
</tr>
<tr class="w3-theme-l3">
<td>High Hourly Rainfall</td>
<td><span data-cmxdata="hourlyrainYH"></span>&nbsp;<span data-cmxdata="rainunit"></span></td>
<td>at <span data-cmxdata="ThourlyrainYH"></span></td>
</tr>
<tr class="w3-theme-l3">
<td>High 24 Hour Rainfall</td>
<td><span data-cmxdata="rain24hourYH"></span>&nbsp;<span data-cmxdata="rainunit"></span></td>
<td>at <span data-cmxdata="Train24hourYH"></span></td>
</tr>
<tr class="w3-theme-d3">
<td colspan="3">Wind</td>
</tr>
<tr class="w3-theme-l4">
<td>High Gust</td>
<td><span data-cmxdata="wgustYM"></span>&nbsp;<span data-cmxdata="windunit"></span></td>
<td>at <span data-cmxdata="TwgustYM"></span></td>
</tr>
<tr class="w3-theme-l4">
<td>High Speed <span class="subText">(10 minute average)</span></td>
<td><span data-cmxdata="windYM"></span>&nbsp;<span data-cmxdata="windunit"></span> (<span data-cmxdata="Ybeaufort"></span>)</td>
<td>at <span data-cmxdata="TwindYM"></span></td>
</tr>
<tr class="w3-theme-l4">
<td>Wind Run</td>
<td><span data-cmxdata="windrunY"></span>&nbsp;<span data-cmxdata="windrununit"></span></td>
<td></td>
</tr>
<tr class="w3-theme-l4">
<td>Dominant Direction</td>
<td><span data-cmxdata="domwindbearingY"></span>&deg; <span data-cmxdata="domwinddirY"></span></td>
<td></td>
</tr>
<tr class="w3-theme-d2">
<td colspan="3">Pressure <span class="subText">(sea level)</span></td>
</tr>
<tr class="w3-theme-l5">
<td>High Pressure</td>
<td><span data-cmxdata="pressYH"></span>&nbsp;<span data-cmxdata="pressunit"></span></td>
<td>at <span data-cmxdata="TpressYH"></span></td>
</tr>
<tr class="w3-theme-l5">
<td>Low Pressure</td>
<td><span data-cmxdata="pressYL"></span>&nbsp;<span data-cmxdata="pressunit"></span></td>
<td>at <span data-cmxdata="TpressYL"></span></td>
</tr>
<tr class="w3-theme-d1 w3-hide" data-cmx-solar data-cmx-uv>
<td colspan="3">Solar</td>
</tr>
<tr class="w3-theme-l6 w3-hide" data-cmx-solar>
<td>High Solar Radiation</td>
<td><span data-cmxdata="solarYH"></span>&nbsp;W/m&sup2;</td>
<td>at <span data-cmxdata="TsolarYH"></span></td>
</tr>
<tr class="w3-theme-l6 w3-hide" data-cmx-solar>
<td>Hours of Sunshine</td>
<td><span data-cmxdata="YSunshineHours"></span>&nbsp;hrs</td>
<td></td>
</tr>
<tr class="w3-theme-l6 w3-hide" data-cmx-uv>
<td>High UV Index</td>
<td><span data-cmxdata="UVYH"></span></td>
<td>at <span data-cmxdata="TUVYH"></span></td>
</tr>
</tbody>
</table>
<p class="w3-small credits">Page updated <span data-cmxdata="update"></span>.</p>
</div>
</div>
</div>
</div>
</div>
<div class="w3-col l3 m12"> <!-- Start of Sidebar 1/4 width -->
<div class="w3-row-padding">
<div class="w3-col l12">
<div class="w3-panel w3-container w3-theme-light">
<h3 class="w3-center">Welcome to <br/><span class="subText"><span data-cmxdata="longlocation"></span></span></h3>
<p>This page shows a summary of the data for the 24 hrs up to <span data-cmxdata="rollovertime"></span> local time. </p>
</div>
</div>
</div>
</div>
</div> <!-- End of panel content -->
</div> <!-- End of content -->
<div id="Footer" class="w3-row w3-bottom w3-theme-dark w3-theme-bdr">
<div class="w3-row-padding site-width">
<p><em>Cumulus MX Template by Neil Thomas <script>document.write(new Date().getFullYear());</script>
<span class="w3-right">Powered by <span class="w3-theme-txt">Cumulus MX</span> v:<span data-cmxdata="version"></span>, b:<span data-cmxdata="build"></span></span></em></p>
</div>
</div>
</body>
</html>

View file

@ -1,149 +0,0 @@
<!DOCYYPE html>
<html lang="en">
<head>
<?php include("../includes/head.inc.php"); ?>
<script>
window.onload = () => {
$('#moonImg').attr('src', '/images/moon.png?' + Date.now());
// update the moon image every 20 minutes if the page is left open
setInterval(() => {
$('#moonImg').attr('src', '/images/moon.png?' + Date.now());
}, 1200000);
};
</script>
</head>
<body>
<div class="page-container">
<?php include("../includes/header.inc.php"); ?>
<div id="content">
<h3>Data for today (<span data-cmxdata="yesterday"></span>)</h3>
<table class="mx-datatable">
<tr>
<th colspan="4">Temperature and Humidity</th>
</tr>
<tr>
<td>High Temperature</td>
<td><span data-cmxdata="tempYH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TtempYH"></span></td>
</tr>
<tr>
<td>Low Temperature</td>
<td><span data-cmxdata="tempYL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TtempYL"></span></td>
</tr>
<tr>
<td>Temperature Range</td>
<td><span data-cmxdata="temprange"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td></td>
</tr>
<tr data-cmx-feels>
<td>High Feels Like</td>
<td><span data-cmxdata="feelslikeYH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TfeelslikeYH"></span></td>
</tr>
<tr data-cmx-feels>
<td>Low Feels Like</td>
<td><span data-cmxdata="feelslikeYL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TfeelslikeYL"></span></td>
</tr>
<tr>
<td>Low Wind Chill</td>
<td><span data-cmxdata="wchillYL"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TwchillYL"></span></td>
</tr>
<tr>
<td>High Heat Index</td>
<td><span data-cmxdata="heatindexYH"></span>&nbsp;<span data-cmxdata="tempunit"></span></td>
<td>at <span data-cmxdata="TheatindexYH"></span></td>
</tr>
<tr>
<td>High Humidity</td>
<td><span data-cmxdata="humYH"></span> %</td>
<td>at <span data-cmxdata="ThumYH"></span></td>
</tr>
<tr>
<td>Low Humidity</td>
<td><span data-cmxdata="humYL"></span> %</td>
<td>at <span data-cmxdata="ThumYL"></span></td>
</tr>
<tr>
<th colspan="4">Rainfall</th>
</tr>
<tr>
<td>Rainfall Today</td>
<td><span data-cmxdata="rfall"></span>&nbsp;<span data-cmxdata="rainunit"></span></td>
<td></td>
</tr>
<tr>
<td>Rainfall Rate Max</td>
<td><span data-cmxdata="rrateYM"></span>&nbsp;<span data-cmxdata="rainunit"></span>/hr</td>
<td>at <span data-cmxdata="TrrateYM"></span></td>
</tr>
<tr>
<td>High Hourly Rainfall</td>
<td><span data-cmxdata="hourlyrainYH"></span>&nbsp;<span data-cmxdata="rainunit"></span></td>
<td>at <span data-cmxdata="ThourlyrainYH"></span></td>
</tr>
<tr>
<td>High 24 Hour Rainfall</td>
<td><span data-cmxdata="rain24hourYH"></span>&nbsp;<span data-cmxdata="rainunit"></span></td>
<td>at <span data-cmxdata="Train24hourYH"></span></td>
</tr>
<tr>
<td>Days Since Last Dry Day</td>
<td><span data-cmxdata="ConsecutiveRainDays"></span></td>
<td></td>
</tr>
<tr>
<td>Days Since It Last Rained</td>
<td><span data-cmxdata="ConsecutiveDryDays"></span></td>
<td></td>
</tr>
<tr>
<th colspan="4">Wind</th>
</tr>
<tr>
<td>High Gust</td>
<td><span data-cmxdata="wgustYM"></span>&nbsp;<span data-cmxdata="windunit"></span></td>
<td>at <span data-cmxdata="TwgustYM"></span></td>
</tr>
<tr>
<td>High Speed <span class="subText">(10 minute average)</span></td>
<td><span data-cmxdata="windYM"></span>&nbsp;<span data-cmxdata="windunit"></span> (<span
data-cmxdata="Tbeaufort"></span>)</td>
<td>at <span data-cmxdata="TwindYM"></span></td>
</tr>
<tr>
<td>Wind Run</td>
<td><span data-cmxdata="windrun"></span>&nbsp;<span data-cmxdata="windrununit"></span></td>
<td></td>
</tr>
<tr>
<td>Dominant Direction</td>
<td><span data-cmxdata="domwindbearing"></span>&deg; <span data-cmxdata="domwinddir"></span>
</td>
<td></td>
</tr>
<tr>
<th colspan="4">Pressure (sea level)</th>
</tr>
<tr>
<td>High Pressure</td>
<td><span data-cmxdata="pressYH"></span>&nbsp;<span data-cmxdata="pressunit"></span></td>
<td>at <span data-cmxdata="TpressYH"></span></td>
</tr>
<tr>
<td>Low Pressure</td>
<td><span data-cmxdata="pressYL"></span>&nbsp;<span data-cmxdata="pressunit"></span></td>
<td>at <span data-cmxdata="TpressYL"></span></td>
</tr>
</table>
<small>Page data updated <span data-cmxdata="update"></span></small>
</div>
<?php include("../includes/footer.inc.php"); ?>
</div>
</body>
</html>