A simple meter using Adafruit 2.8 TFT with touch v2
Dependencies: SPI_STMPE610 UniGraphic mbed vt100
A dumb simple voltage tester using ADC.
With FRDM-KL25Z, you can measure about 0V to 3.28V.
Nothing to drop your jaw nor holding your breath
but I wanted one, so I wrote one ;-)
とても単純はADCを使用した電圧テスターです。
FRDM-KL25Z を使用した場合、0V ~ 3.28V くらいが測定範囲です。
特に目新しいことも、驚くこともありませんが、
自分が欲しいので書いてみました (^ - ^)
On 18-May-2018
I changed the number display from 0.00 to 0.000
so that I can measure the change of a small loadcell.
2018年5月18日
ロードセル (重量センサ)の出力値の変化を見たかったので
有効数字を小数点以下2桁から3桁に変更しました。
Diff: meter.cpp
- Revision:
- 3:bf8761c8eb17
- Parent:
- 2:204e60dbd73d
- Child:
- 4:0607a2a46238
diff -r 204e60dbd73d -r bf8761c8eb17 meter.cpp
--- a/meter.cpp Fri Jul 21 01:24:53 2017 +0000
+++ b/meter.cpp Fri Jul 21 02:01:05 2017 +0000
@@ -2,25 +2,18 @@
#include <math.h>
#include <string.h>
#include "ILI9341.h"
-#include "Arial12x12.h"
-#include "Arial24x23.h"
#include "Arial28x28.h"
-#include "Arial43x48_numb.h"
-#include "SPI_STMPE610.h"
#include "meter.h"
-#include "vt100.h"
#include "main.h"
#ifndef M_PI
#define M_PI 3.141593
#endif
-extern vt100 *tty ;
extern ILI9341 *tft ;
-extern SPI_STMPE610 *tsc ;
extern meter *tacho ;
-double SIN[451] ;
-double COS[451] ;
+double SIN[451] ; /* sin table for 45 to 90 degrees in 0.1 deg step */
+double COS[451] ; /* cos table for 45 to 90 degrees in 0.1 deg step */
static void fillTriTable(void)
{
@@ -39,7 +32,6 @@
_y = y ;
_w = width ;
_h = height ;
- _value = min ;
_min = min ;
_max = max ;
_center_x = _x + _w / 2 ;
@@ -97,11 +89,11 @@
if (theta < 0.0) { theta = 0.0 ; }
if (theta > 90.0) { theta = 90.0 ; }
if (theta > 45.0) {
- i = (10.0 * (90.0 - theta + 45.0) + 0.5) - 450 ;
- x1 = _center_x -(radius * COS[i] + 0.5) ;
- x2 = _center_x -((radius + append) * COS[i] + 0.5) ;
+ i = (10.0 * (90.0 - theta) + 0.5) ;
+ x1 = _center_x - (radius * COS[i] + 0.5) ;
+ x2 = _center_x - ((radius + append) * COS[i] + 0.5) ;
} else {
- i = (10.0 * (theta + 45.0) + 0.5) - 450 ;
+ i = (10.0 * theta + 0.5) ;
x1 = _center_x + (radius * COS[i] + 0.5) ;
x2 = _center_x + ((radius + append) * COS[i] + 0.5) ;
}
@@ -109,8 +101,8 @@
y1 = _center_y - (radius * SIN[i] + 0.5) ;
y2 = _center_y - ((radius + append) * SIN[i] + 0.5) ;
tft->BusEnable(true) ;
- tft->line(prev_x1, prev_y1, prev_x2, prev_y2, White) ;
- tft->line(x1, y1, x2, y2, Black) ;
+ tft->line(prev_x1, prev_y1, prev_x2, prev_y2, White) ; /* erase prev */
+ tft->line(x1, y1, x2, y2, Black) ; /* draw current */
tft->BusEnable(false) ;
prev_x1 = x1 ;
prev_x2 = x2 ;
@@ -118,14 +110,13 @@
prev_y2 = y2 ;
}
-void meter::draw(void)
-{
-}
-
void meter::draw(float value)
{
tft->BusEnable(true) ;
- drawHand(_value) ;
+ drawFrame() ;
+ drawScale() ;
+ drawHand(value) ;
+ drawValue(value) ;
tft->BusEnable(false) ;
}
@@ -145,4 +136,8 @@
void meter::update(float value)
{
+ tft->BusEnable(true) ;
+ drawHand(value) ;
+ drawValue(value) ;
+ tft->BusEnable(false) ;
}
\ No newline at end of file