——Vom DWIN-Entwicklerforum
In dieser Ausgabe stellen wir Ihnen den preisgekrönten Open-Source-Fall des DWIN Developer Forums vor: Intelligent Cat Food Control System.Ingenieure verwendeten den DWIN-Smart-Screen, um die Temperatur, die Luftfeuchtigkeit und die verbleibende Menge an Katzenfutter zu überwachen und die Aufzeichnungen über die Futteraufnahme der Katze zu speichern.Sie haben außerdem auf einzigartige Weise eine Reihe von Benutzeroberflächen im Tintenmalstil sowie einen Tintenklickeffekt bei Berührung mit dem Finger entworfen, um die visuelle Wahrnehmung des Berührungsfeedbacks zu verbessern.
Einführung:
1.UI-Bildmaterial
Der DWIN Smart Screen schließt die UI-Entwicklung basierend auf Bildern, Audio und anderen Materialien ab, die entsprechend dem Bildschirminhalt im Voraus vorbereitet werden müssen.
2. Schnittstellenentwicklung
Die DGUS-Software stellt den UI-Effekt durch Ebenenüberlagerung wieder her, kombiniert die vorbereiteten Materialien in der DGUS-Software zu einem vollständigen Bild und stellt die Anzeige- und Touch-Funktionen ein.
3. Implementieren Sie Klickeffekte und Soundeffekte
Die Berührungsposition wird durch das 51-Programm ermittelt, der Druckeffekt folgt der Bewegung des Fingers und der Toneffekt der Tastenbegleitung wird ebenfalls erzielt.
(1) Touch-Standortcode erkennen und Audio abspielen:
void TouchDetect()
{
u16 Va[3] = 0;
u8 i = 0;
for(i = 0;i < 3;i++)
{
Va[i] = Read_Dgus(0x0016 + i);
if(Va[0] == 0x5A01)
{
}
anders
{
brechen;
}
}
if(i != 0) //Zuerst klicken, um einzutreten
{
u16 play[2] = {0x0001, 0x4000};
touchAnimationFlag = 1;
touchAnimationCnt = 0;
touchPosX = Va[1];
touchPosY = Va[2];
write_dgus_vp(0x00A0, play, 2);
}
}
(2) Der Code für die Touch-Effekt-Anzeige lautet wie folgt:
void TouchStart()
{
if(touchAnimationFlag == 1)
{
if(touchAnimationCnt == 0)
{
Write_Dgus(0x5011, touchPosX - 100);
Write_Dgus(0x5012, touchPosY - 100);
}
Write_Dgus(0x5000, touchAnimationCnt);
touchAnimationCnt++;
if(touchAnimationCnt == 6)
{
touchAnimationFlag = 0;
Write_Dgus(0x5011, 1024);
Write_Dgus(0x5012, 600);
}
}
}
4. Der nächste Schritt besteht darin, die entsprechenden Parameter über den Bildschirm einzustellen und die Daten dann über ESP32 an den Katzenfutter-Controller zu übertragen, um die automatische Fütterungsfunktion von Katzenfutter zu realisieren.Der spezifische Code lautet wie folgt:
//Schaltflächenstatus abrufen
void get_key_status()
{
int i = 0;
//u16 Va=Read_Dgus(addr);
u16 Va=Read_Dgus(0x1000);
if(Va != 0x0000)
{
//STatus-Seite
if(Va == 0x0103) //Platziere die Anzahl von g
{
u16 switchpage[2] = {0x5A01, 19};
setNum = placeGramNum;
backPage = 1;//Zurück zur Statusseite
Write_Dgus(0x4000 + 0, setNum % 10);
Write_Dgus(0x4000 + 2, setNum / 10 % 10);
Write_Dgus(0x4000 + 4, setNum / 100 % 10);
Write_Dgus(0x4000 + 6, setNum / 1000 % 10);
write_dgus_vp(0x0084, switchpage, 2);
}
sonst if(Va == 0x0102)
{
OneSendData3(placeGramNum);//OrtKatzenfuttereinmal
}
else if(Va == 0x0101) //Einstellungsseite
{
u16 switchpage[2] = {0x5A01, 3};
for(i = 0;i < 6;i++)
{
if(i == 0)
{
Write_Dgus(0x3070 + i * 0x10 + 0, currentTime[i] % 10);
Write_Dgus(0x3070 + i * 0x10 + 2, currentTime[i] / 10 % 10);
Write_Dgus(0x3070 + i * 0x10 + 4, currentTime[i] / 100 % 10);
Write_Dgus(0x3070 + i * 0x10 + 6, currentTime[i] / 1000 % 10);
}
anders
{
Write_Dgus(0x3070 + i * 0x10 + 0, currentTime[i] % 10);
Write_Dgus(0x3070 + i * 0x10 + 2, currentTime[i] / 10 % 10);
}
}
write_dgus_vp(0x0084, switchpage, 2);//Geben Sie die Einstellungsseite ein
}
sonst if(Va == 0x0100) //RRekordseite
{
u16 switchpage[2] = {0x5A01, 2};
for(i = 0;i < 6;i++)
{
if(i == 0)
{
Write_Dgus(0x2000 + i * 0x10 + 0, eatFeedList[0][i] % 10);
Write_Dgus(0x2000 + i * 0x10 + 2, eatFeedList[0][i] / 10 % 10);
Write_Dgus(0x2000 + i * 0x10 + 4, eatFeedList[0][i] / 100 % 10);
Write_Dgus(0x2000 + i * 0x10 + 6, eatFeedList[0][i] / 1000 % 10);
}
anders
{
Write_Dgus(0x2000 + i * 0x10 + 0, eatFeedList[0][i] % 10);
Write_Dgus(0x2000 + i * 0x10 + 2, eatFeedList[0][i] / 10 % 10);
}
}
write_dgus_vp(0x0084, switchpage, 2);//Datensatzseite eingeben
}
//RRekordseite
else if(Va == 0x0201) //Seite vorherige Seite aufzeichnen
{
if(lookEatCnt > 0)
{
lookEatCnt--;
for(i = 0;i < 6;i++)
{
if(i == 0)
{
Write_Dgus(0x2000 + i * 0x10 + 0, eatFeedList[lookEatCnt][i] % 10);
Write_Dgus(0x2000 + i * 0x10 + 2, eatFeedList[lookEatCnt][i] / 10 % 10);
Write_Dgus(0x2000 + i * 0x10 + 4, eatFeedList[lookEatCnt][i] / 100 % 10);
Write_Dgus(0x2000 + i * 0x10 + 6, eatFeedList[lookEatCnt][i] / 1000 % 10);
}
anders
{
Write_Dgus(0x2000 + i * 0x10 + 0, eatFeedList[lookEatCnt][i] % 10);
Write_Dgus(0x2000 + i * 0x10 + 2, eatFeedList[lookEatCnt][i] / 10 % 10);
}
}
}
}
else if(Va == 0x0202) //Seite aufzeichnen, nächste Seite
{
if(lookEatCnt < eatCnt - 1)
{
lookEatCnt++;
for(i = 0;i < 6;i++)
{
if(i == 0)
{
Write_Dgus(0x2000 + i * 0x10 + 0, eatFeedList[lookEatCnt][i] % 10);
Write_Dgus(0x2000 + i * 0x10 + 2, eatFeedList[lookEatCnt][i] / 10 % 10);
Write_Dgus(0x2000 + i * 0x10 + 4, eatFeedList[lookEatCnt][i] / 100 % 10);
Write_Dgus(0x2000 + i * 0x10 + 6, eatFeedList[lookEatCnt][i] / 1000 % 10);
}
anders
{
Write_Dgus(0x2000 + i * 0x10 + 0, eatFeedList[lookEatCnt][i] % 10);
Write_Dgus(0x2000 + i * 0x10 + 2, eatFeedList[lookEatCnt][i] / 10 % 10);
}
}
}
}
//Einstellungsseite
sonst if(Va == 0x0302)
{
if(timeMode == 1)
{
timeMode = 0;
Write_Dgus(0x3A12, 139);
}
}
sonst if(Va == 0x0303)
{
if(timeMode == 0)
{
timeMode = 1;
Write_Dgus(0x3A12, 242);
}
}
sonst if(Va >= 0x0304 && Va <= 0x0309)
{
u16 switchpage[2] = {0x5A01, 19};
backPage = 3;
backNum = Va;
setNum = timrIntervalHour[Va - 0x0304];
Write_Dgus(0x4000 + 0, setNum % 10);
Write_Dgus(0x4000 + 2, setNum / 10 % 10);
Write_Dgus(0x4000 + 4, setNum / 100 % 10);
Write_Dgus(0x4000 + 6, setNum / 1000 % 10);
write_dgus_vp(0x0084, switchpage, 2);
}
sonst wenn(Va >= 0x030A && Va <= 0x030F)
{
u16 switchpage[2] = {0x5A01, 19};
backPage = 3;
backNum = Va;
setNum = currentTime[Va - 0x030A];
Write_Dgus(0x4000 + 0, setNum % 10);
Write_Dgus(0x4000 + 2, setNum / 10 % 10);
Write_Dgus(0x4000 + 4, setNum / 100 % 10);
Write_Dgus(0x4000 + 6, setNum / 1000 % 10);
write_dgus_vp(0x0084, switchpage, 2);
}
//ADatenseite anpassen
sonst if(Va == 0x0400) //Bestätigen
{
u16 switchpage[2] = {0x5A01, 0x0000};
switchpage[1] = backPage;
if(backPage == 1) //Zurück zur Statusseite
{
placeGramNum = setNum;
Write_Dgus(0x1140 + 0, placeGramNum % 10);
Write_Dgus(0x1140 + 2, placeGramNum / 10 % 10);
}
sonst if(backPage == 3)
{
if(backNum >= 0x0304 && backNum <= 0x0309)
{
u16 select = 0;
select = (backNum - 0x0304) * 0x10;
timrIntervalHour[backNum - 0x0304] = setNum;
Write_Dgus(0x3010 + select + 0, setNum % 10);
Write_Dgus(0x3010 + select + 2, setNum / 10 % 10);
}
sonst if(backNum >= 0x030A && backNum <= 0x030F)
{
u16 select = 0;
select = (backNum - 0x0304) * 0x10;
currentTime[backNum - 0x030A] = setNum;
if(backNum == 0x030A)
{
Write_Dgus(0x3010 + select + 0, setNum % 10);
Write_Dgus(0x3010 + select + 2, setNum / 10 % 10);
Write_Dgus(0x3010 + select + 4, setNum / 100 % 10);
Write_Dgus(0x3010 + select + 6, setNum / 1000 % 10);
}
anders
{
Write_Dgus(0x3010 + select + 0, setNum % 10);
Write_Dgus(0x3010 + select + 2, setNum / 10 % 10);
}
}
}
write_dgus_vp(0x0084, switchpage, 2);
}
sonst if(Va == 0x0401) //Zurück
{
u16 switchpage[2] = {0x5A01, 0x0000};
switchpage[1] = backPage;
write_dgus_vp(0x0084, switchpage, 2);
}
else if(Va == 0x0402) //Numerische Erhöhung
{
setNum++;
Write_Dgus(0x4000 + 0, setNum % 10);
Write_Dgus(0x4000 + 2, setNum / 10 % 10);
Write_Dgus(0x4000 + 4, setNum / 100 % 10);
Write_Dgus(0x4000 + 6, setNum / 1000 % 10);
}
else if(Va == 0x0403) //Numerische Abnahme
{
if(setNum > 0)
setNum--;
Write_Dgus(0x4000 + 0, setNum % 10);
Write_Dgus(0x4000 + 2, setNum / 10 % 10);
Write_Dgus(0x4000 + 4, setNum / 100 % 10);
Write_Dgus(0x4000 + 6, setNum / 1000 % 10);
}
Write_Dgus(0x1000, 0);
}
}
Zeitpunkt der Veröffentlichung: 19.09.2023