-
Notifications
You must be signed in to change notification settings - Fork 32
/
splash.cpp
69 lines (63 loc) · 2.42 KB
/
splash.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/**
* This file is part of Wio LoRaWan Field Tester.
*
* Wio LoRaWan Field Tester is free software created by Paul Pinault aka disk91.
* You can redistribute it and/or modify it under the terms of the
* GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* any later version.
*
* Wio LoRaWan Field Tester is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Wio LoRaWan Field Tester. If not, see <https://www.gnu.org/licenses/>.
*
* Author : Paul Pinault (disk91.com)
*/
#include <Arduino.h>
#include "config.h"
#include "helium_logo.h"
#include "ttn_logo.h"
#include "ui.h"
void draw_splash_helium(int xOffset, int yOffset, int density) {
const char * logo = helium_data;
for ( int y = yOffset ; y < yOffset+helium_height ; y++ ) {
for ( int x = xOffset ; x < xOffset+helium_width ; x++) {
uint8_t pixel[3];
HELIUM_PIXEL(logo,pixel);
uint16_t r = ((pixel[0] >> 3) * density) / 100;
uint16_t g = ((pixel[1] >> 2) * density) / 100;
uint16_t b = ((pixel[2] >> 3) * density) / 100;
uint16_t color = ( ( r << 11 ) & 0xF800 ) | ( ( g << 5 ) & 0x07E0 ) | ( b & 0x001F );
if ( pixel[2] > 2*pixel[0] ) {
tft.drawPixel(x,y,color);
}
}
}
}
void draw_splash_ttn(int xOffset, int yOffset, int density) {
const char * logo = ttn_data;
for ( int y = yOffset ; y < yOffset+ttn_height ; y++ ) {
for ( int x = xOffset ; x < xOffset+ttn_width ; x++) {
uint8_t pixel[3];
uint16_t r,g,b;
HELIUM_PIXEL(logo,pixel);
if ( pixel[0]+pixel[1]+pixel[2] < 50 ) {
r = ((0xFF >> 3) * density) / 100;
g = ((0xFF >> 2) * density) / 100;
b = ((0xFF >> 3) * density) / 100;
} else {
r = ((pixel[0] >> 3) * density) / 100;
g = ((pixel[1] >> 2) * density) / 100;
b = ((pixel[2] >> 3) * density) / 100;
}
uint16_t color = ( ( r << 11 ) & 0xF800 ) | ( ( g << 5 ) & 0x07E0 ) | ( b & 0x001F );
if ( pixel[2] > 2*pixel[0] || ( pixel[0]+pixel[1]+pixel[2] < 50 ) ) {
tft.drawPixel(x,y,color);
}
}
}
}