| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357 | /** *  @filename   :   epd2in66g.cpp *  @brief      :   Implements for e-paper library *  @author     :   Waveshare * *  Copyright (C) Waveshare     2022/08/17 * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documnetation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to  whom the Software is * furished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS OR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */#include <stdlib.h>#include "epd5in79g.h"Epd::~Epd() {};Epd::Epd() {    reset_pin = RST_PIN;    dc_pin = DC_PIN;    cs_pin = CS_PIN;    busy_pin = BUSY_PIN;    WIDTH = EPD_WIDTH;    HEIGHT = EPD_HEIGHT;};int Epd::Init() {    /* this calls the peripheral hardware interface, see epdif */    if (IfInit() != 0) {        return -1;    }    Reset();    SendCommand(0xA2);	//********************    SendData(0x01);    SendCommand(0x00);	//0x00    SendData(0x03);	    SendData(0x29);    SendCommand(0xA2);	//********************    SendData(0x02);	    SendCommand(0x00);	//0x00    SendData(0x07);	    SendData(0x29);    SendCommand(0xA2);	//********************    SendData(0x00);	    SendCommand(0x50);	//    SendData(0x97);	    SendCommand(0x61); //0x61	    SendData(0x01);	    SendData(0x8c);	    SendData(0x01);	    SendData(0x10); 	    SendCommand(0x06);	//0x06    SendData(0x38);	    SendData(0x38);    SendData(0x38);    SendData(0x00);	//////////////////////////////////////////    SendCommand(0xE9);	//0xE0    SendData(0x01);    SendCommand(0xE0);	//0xE0    SendData(0x01);    SendCommand(0x04);    ReadBusyH();  //while(1);	    return 0;}/** *  @brief: basic function for sending commands */void Epd::SendCommand(unsigned char command) {    DigitalWrite(dc_pin, LOW);    SpiTransfer(command);}/** *  @brief: basic function for sending data */void Epd::SendData(unsigned char data) {    DigitalWrite(dc_pin, HIGH);    SpiTransfer(data);}/** *  @brief: Wait until the busy_pin goes LOW */void Epd::ReadBusyH(void) {    Serial.print("e-Paper busy H\r\n ");    while(DigitalRead(busy_pin) == LOW) {      //LOW: busy, HIGH: idle        DelayMs(5);    }     Serial.print("e-Paper busy release H\r\n ");    }void Epd::ReadBusyL(void) {    Serial.print("e-Paper busy L\r\n ");    while(DigitalRead(busy_pin) == HIGH) {      //LOW: idle, HIGH: busy        DelayMs(5);    }          Serial.print("e-Paper busy release L\r\n ");}/** *  @brief: module reset. *          often used to awaken the module in deep sleep, *          see Epd::Sleep(); */void Epd::Reset(void) {    DigitalWrite(reset_pin, HIGH);    DelayMs(20);        DigitalWrite(reset_pin, LOW);                //module reset        DelayMs(2);    DigitalWrite(reset_pin, HIGH);    DelayMs(20);     }/******************************************************************************function :	Turn On Displayparameter:******************************************************************************/void Epd::TurnOnDisplay(void){    SendCommand(0xA2);     SendData(0x00);    SendCommand(0x12);     SendData(0x00);    ReadBusyH();}/******************************************************************************function :	Clear screenparameter:******************************************************************************/void Epd::Clear(UBYTE color){    UWORD Width, Height;    Width = (WIDTH % 8 == 0)? (WIDTH / 8 ): (WIDTH / 8 + 1);    Height = HEIGHT;    SendCommand(0xA2);	//********************    SendData(0x01);    SendCommand(0x10);    for (UWORD j = 0; j < Height; j++) {        for (UWORD i = 0; i < Width; i++) {            SendData((color<<6) | (color<<4) | (color<<2) | color);        }    }    SendCommand(0xA2);	//********************    SendData(0x02);    SendCommand(0x10);    for (UWORD j = 0; j < Height; j++) {        for (UWORD i = 0; i < Width; i++) {            SendData((color<<6) | (color<<4) | (color<<2) | color);        }    }    TurnOnDisplay();}/******************************************************************************function :	Sends the image buffer in RAM to e-Paper and displaysparameter:******************************************************************************/void Epd::Display(UBYTE *Image){    UWORD Width, Height, Width1;    Width1 = (WIDTH % 4 == 0)? (WIDTH / 4 ): (WIDTH / 4 + 1);    Width =(WIDTH % 8 == 0)?(WIDTH / 8 ):(WIDTH / 8 + 1);    Height = HEIGHT;    SendCommand(0xA2);	//********************    SendData(0x01);    SendCommand(0x10);        for (UWORD j = 0; j < Height/2; j++) {        for (UWORD i = 0; i < Width; i++) {            SendData(pgm_read_byte(&Image[i + j * Width1]));        }        for (UWORD i = 0; i < Width; i++) {            SendData(pgm_read_byte(&Image[i + (Height - j - 1) * Width1]));        }    }    SendCommand(0xA2);	//********************    SendData(0x02);    SendCommand(0x10);    for (UWORD j = 0; j < Height; j++) {        for (UWORD i = 0; i < Width; i++) {            SendData(pgm_read_byte(&Image[j * Width1 + i + Width]));        }        for (UWORD i = 0; i < Width; i++) {            SendData(pgm_read_byte(&Image[(Height - j - 1) * Width1 + i + Width]));        }    }    TurnOnDisplay();}void Epd::Display_part(UBYTE *Image, UWORD xstart, UWORD ystart, UWORD image_width, UWORD image_height){    UWORD Width, Width1, Width2, Height, i, j, xend, yend;    Width = (WIDTH % 8 == 0)? (WIDTH / 8 ): (WIDTH / 8 + 1);    Height = HEIGHT;    xend = xstart + image_width;    yend = ystart + image_height;    if(xstart>395)    {        xstart = xstart - 396 ;        xend = xstart + image_width;        SendCommand(0xA2);        SendData(0x01);        SendCommand(0x10);        for (UWORD j = 0; j < Height/2; j++) {            for (UWORD i = 0; i < Width; i++) {                if(j >= ystart && i < xend/4 && i >= xstart/4)                    SendData(pgm_read_byte(&Image[(j - ystart) * image_width/4 + i - xstart/4]));                else                    SendData(0x55);            }            for (UWORD i = 0; i < Width; i++) {                if((Height - j) < yend && i < xend/4 && i >= xstart/4)                    SendData(pgm_read_byte(&Image[(yend - (Height - j)) * image_width/4 + i- xstart/4]));                else                    SendData(0x55);            }         }        SendCommand(0xA2);        SendData(0x02);        SendCommand(0x10);        for (UWORD j = 0; j < Height; j++) {            for (UWORD i = 0; i < Width; i++) {                    SendData(0x55);            }        }    }    else if(xend<396)    {        xend = xstart + image_width;        SendCommand(0xA2);        SendData(0x01);        SendCommand(0x10);        for (UWORD j = 0; j < Height; j++) {            for (UWORD i = 0; i < Width; i++) {                    SendData(0x55);            }        }        SendCommand(0xA2);        SendData(0x02);        SendCommand(0x10);        for (UWORD j = 0; j < Height/2; j++) {            for (UWORD i = 0; i < Width; i++) {                if(j >= ystart && i < xend/4 && i >= xstart/4)                    SendData(pgm_read_byte(&Image[(j - ystart) * image_width/4 + i - xstart/4]));                else                    SendData(0x55);            }            for (UWORD i = 0; i < Width; i++) {                if((Height - j) < yend && i < xend/4 && i >= xstart/4)                    SendData(pgm_read_byte(&Image[(yend - (Height - j)) * image_width/4 + i- xstart/4]));                else                    SendData(0x55);            }         }    }    else    {        xend = xstart + image_width;        Width1 = ((395 - xstart) % 4 == 0)?((395 - xstart) / 4 ):((395 - xstart) / 4 + 1);        Width2 = ((xend - 396) % 4 == 0)?((xend - 396) / 4 ):((xend - 396) / 4 + 1);        SendCommand(0xA2);        SendData(0x01);        SendCommand(0x10);        for (UWORD j = 0; j < Height/2; j++) {            for (UWORD i = 0; i < Width; i++) {                if(j >= ystart && i < Width2)                    SendData(pgm_read_byte(&Image[(j - ystart) * image_width/4 + i + Width1]));                else                    SendData(0x55);            }            for (UWORD i = 0; i < Width; i++) {                if((Height - j) < yend && i < Width2)                    SendData(pgm_read_byte(&Image[(yend - (Height - j)) * image_width/4 + i + Width1]));                else                    SendData(0x55);            }         }        SendCommand(0xA2);        SendData(0x02);        SendCommand(0x10);        for (UWORD j = 0; j < Height/2; j++) {            for (UWORD i = 0; i < Width; i++) {                if(j >= ystart && i >= xstart/4)                    SendData(pgm_read_byte(&Image[(j - ystart) * image_width/4 + i - xstart/4]));                else                    SendData(0x55);            }            for (UWORD i = 0; i < Width; i++) {                if((Height - j) < yend && i >= xstart/4)                    SendData(pgm_read_byte(&Image[(yend - (Height - j)) * image_width/4 + i- xstart/4]));                else                    SendData(0x55);            }         }    }    TurnOnDisplay();}/******************************************************************************function :	Enter sleep modeparameter:******************************************************************************/void Epd::Sleep(void){    // SendCommand(0x02); // POWER_OFF    // SendData(0X00);    // ReadBusyH();        SendCommand(0x07); // DEEP_SLEEP    SendData(0XA5);}/* END OF FILE */
 |