improved rectangle

This commit is contained in:
Emanuele Trabattoni
2021-06-06 19:54:21 +02:00
parent 54fabc151d
commit d910980ede
4 changed files with 37 additions and 19 deletions

View File

@@ -9,7 +9,8 @@ namespace Render {
_screenSize(size),
_screenBufferBackground(nullptr),
_screenBufferForeground(nullptr),
_rotation(rot)
_rotation(rot),
_full(true)
{
int rv;
_bufferDim = (_screenSize.x >> 3) * _screenSize.y;
@@ -49,7 +50,12 @@ namespace Render {
if (d != nullptr)
d->render();
};
if (!_full)
EPD_2IN9_V2_Display_Partial(_screenBufferBackground);
else {
EPD_2IN9_V2_Display(_screenBufferBackground);
_full = false;
}
}
void Mare::clearBuffer(uint8_t* buffer, uint16_t len, Color col){
@@ -126,7 +132,7 @@ namespace Render {
void Mare::clearScreen() {
EPD_2IN9_V2_Clear();
clearBuffer(_screenBufferBackground, _bufferDim, Color::White);
EPD_2IN9_V2_Display(_screenBufferBackground);
_full = true;
}
}

View File

@@ -116,6 +116,7 @@ namespace Render{
uint16_t _bufferDim;
Drawables _drawables; // background drawables for all the pages
ScreenRotation _rotation;
bool _full;
public:
uint8_t* bBuffer() { return _screenBufferBackground; }
@@ -188,7 +189,11 @@ namespace Render{
~DrawableLine();
public:
void setThickness(uint16_t thickness) {_thickness = thickness;};
void setThickness(uint16_t thickness) {
uint8_t d = thickness >> 1;
_thickness = thickness;
_ofst = (d % 2)==0 ? d + 1: d;
};
const uint16_t getThickness() {return _thickness;};
void setRotation(uint16_t rotation) {_rotation = rotation;};
const uint16_t getRotation() {return _rotation;};
@@ -203,6 +208,7 @@ namespace Render{
uint16_t _thickness;
uint16_t _length;
uint16_t _rotation;
uint8_t _ofst;
};
class DrawableRectangle: public Drawable {

View File

@@ -57,7 +57,7 @@ namespace Render {
_length(0),
_rotation(0)
{
setThickness(_thickness); // only to calc offset
}
DrawableLine::~DrawableLine()
@@ -82,7 +82,7 @@ namespace Render {
res.x = t-(_thickness>>1);
res.y = _rotation == 90 ? xx : _length-xx;
} else {
res = e->rotateXY(xx,t-(_thickness>>1),_rotation/180.0f*M_PI);
res = e->rotateXY(xx,t-_ofst,_rotation/180.0f*M_PI);
}
e->setPixel(buf,res.x+o.x,res.y+o.y,getBlendMode());
@@ -113,15 +113,13 @@ namespace Render {
void DrawableRectangle::createOutline(){
auto e = engine();
pos_t o = getOrigin();
float cx,sx;
auto rf = (_rotation % 360)/180.0f*M_PI;
if (l1 == nullptr) l1 = e->addDrawable<DrawableLine>();
if (l2 == nullptr) l2 = e->addDrawable<DrawableLine>();
if (l3 == nullptr) l3 = e->addDrawable<DrawableLine>();
if (l4 == nullptr) l4 = e->addDrawable<DrawableLine>();
_rotation %= 360;
sincosf(_rotation/180.0f*M_PI, &sx, &cx);
l1->setRotation(_rotation);
l1->setLength(_dim.x);
l1->setThickness(_thickness);
@@ -135,10 +133,18 @@ namespace Render {
l4->setLength(_dim.y);
l4->setThickness(_thickness);
uint8_t of = l2->_ofst;
pos_t res = {0,0};
l1->setOrigin(o);
l2->setOrigin({(p_t)(o.x+(_dim.x-_thickness+1)*cx), (p_t)(o.y+(_dim.x-_thickness+1)*sx)});
l3->setOrigin({(p_t)(o.x-(_dim.y-_thickness+1)*sx), (p_t)(o.y+(_dim.y-_thickness+1)*cx)});
l4->setOrigin(o);
res = e->rotateXY((_dim.x-of),0,rf);
l2->setOrigin({(p_t)(o.x+res.x), (p_t)(o.y+res.y)});
res = e->rotateXY(0,(_dim.y-of),rf);
l3->setOrigin({(p_t)(o.x+res.x), (p_t)(o.y+res.y)});
res = e->rotateXY(of,-of,rf);
l4->setOrigin({(p_t)(o.x+res.x), (p_t)(o.y+res.y)});
l1->setDirty();
l2->setDirty();

View File

@@ -37,17 +37,17 @@ int main(){
line3->setOrigin(viewer.getCenter());
line3->setBlendMode(Render::BlendMode::Add);
rect->setDimension({48,32});
rect->setOrigin({8,8});
rect->setDimension({48,48});
rect->setOrigin(viewer.getCenter());
rect->setOutline(true);
rect->setThickness(3);
rect->setThickness(6);
while (true){
line3->setThickness(2);
for (uint16_t a(0); a<=360; a+=360/32){
line3->setRotation(a);
//rect->setRotation(a);
line3->setDirty();
for (uint16_t a(0); a<=360; a+=360/36){
//line3->setRotation(a);
rect->setRotation(a);
//line3->setDirty();
c1->setDirty();
c2->setDirty();
rect->setDirty();