[Caso premiado] Sistema inteligente de controle de alimentos para gatos

——Do Fórum de Desenvolvedores DWIN

Nesta edição, apresentaremos a você o premiado caso de código aberto do Fórum de Desenvolvedores DWIN: Sistema Inteligente de Controle de Alimentos para Gatos.Os engenheiros usaram a tela inteligente DWIN para monitorar a temperatura, a umidade e a quantidade restante de comida de gato e para salvar os registros de ingestão de comida do gato.Eles também projetaram exclusivamente um conjunto de interface de usuário com estilo de pintura a tinta, bem como um efeito de clique de tinta quando tocado por um dedo, para melhorar a percepção visual do feedback do toque.

Introdução:

1.Material de imagem da interface do usuário

A tela inteligente DWIN completa o desenvolvimento da UI com base em imagens, áudio e outros materiais que precisam ser preparados com antecedência de acordo com o conteúdo da tela.

asv (2)

2.Desenvolvimento de interface

O software DGUS restaura o efeito da interface do usuário através da sobreposição de camadas, combina os materiais preparados em uma imagem completa no software DGUS e define as funções de exibição e toque.

asv (1)

3. Implemente efeitos de clique e efeitos sonoros

A posição de toque é obtida através do programa 51, o efeito de pressão segue o movimento do dedo e o efeito sonoro de acompanhamento das teclas também é obtido.

(1) Detecte o código de localização de toque e reproduza áudio:

void TouchDetect()

{

    u16 Va[3] = 0;

    u8 eu = 0;

 

    para(eu = 0;eu < 3;eu++)

    {

        Va[i] = Read_Dgus(0x0016 + i);

        se(Va[0] == 0x5A01)

        {

        }

        outro

        {

            quebrar;

        }

    }

    if(i != 0) //Primeiro clique para entrar

    {

        u16 jogar[2] = {0x0001, 0x4000};

        touchAnimationFlag = 1;

        touchAnimationCnt = 0;

        toquePosX = Va[1];

        toquePosY = Va[2];

        write_dgus_vp(0x00A0, reprodução, 2);

    }

}

 

(2) O código para exibição do efeito de toque é o seguinte:

vazio 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. A próxima etapa é definir os parâmetros correspondentes por meio da tela e, em seguida, transmitir os dados para o controlador de ração de gato por meio do ESP32 para realizar a função de alimentação automática de ração de gato.O código específico é o seguinte:

//Obtém o status do botão

vazio get_key_status()

{

    int eu = 0;

    //u16 Va=Read_Dgus(addr);

    u16 Va=Read_Dgus(0x1000);

    se(Va!= 0x0000)

    {

        //Spágina de tatuagens

        if(Va == 0x0103) //Coloque o número de g

        {

            u16 alternância[2] = {0x5A01, 19};

            setNum = placeNumGram;

            backPage = 1;//Retorna à página de status

            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);

        }

        senão se(Va == 0x0102)

        {

            OneSendData3(placeGramNum);//Lugarcomida de gatouma vez

        }

        else if(Va == 0x0101) //Página de configuração

        {

            u16 alternância[2] = {0x5A01, 3};

            para(eu = 0;eu < 6;eu++)

            {

                se(eu == 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);

                }

                outro

                {

                    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);//Entra na página de configurações

        }

        senão if(Va == 0x0100) //Rpágina de registro

        {

            u16 switchpage[2] = {0x5A01, 2};

            para(eu = 0;eu < 6;eu++)

            {

                se(eu == 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);

                }

                outro

                {

                    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);//Entra na página de registro

        }

        //Rpágina de registro

        else if(Va == 0x0201) //Registra a página anterior

        {

            if(lookEatCnt > 0)

            {

                lookEatCnt--;

                para(eu = 0;eu < 6;eu++)

                {

                    se(eu == 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);

                    }

                    outro

                    {

                        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) //Grava página próxima página

        {

            if(lookEatCnt < comerCnt - 1)

            {

                lookEatCnt++;

                para(eu = 0;eu < 6;eu++)

                {

                    se(eu == 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);

                    }

                    outro

                    {

                        Write_Dgus(0x2000 + i * 0x10 + 0, eatFeedList[lookEatCnt][i] % 10);

                        Write_Dgus(0x2000 + i * 0x10 + 2, eatFeedList[lookEatCnt][i] / 10% 10);

                    }

                }

            }

        }

        //Página de configuração

        senão se(Va == 0x0302)

        {

            if(timeMode == 1)

            {

                timeMode = 0;

                Write_Dgus(0x3A12, 139);

            }

        }

        senão se(Va == 0x0303)

        {

            if(timeMode == 0)

            {

                timeMode = 1;

                Write_Dgus(0x3A12, 242);

            }

        }

        senão if(Va >= 0x0304 && Va <= 0x0309)

        {

            u16 alternância[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);

        }

        senão if(Va >= 0x030A && Va <= 0x030F)

        {

            u16 alternância[2] = {0x5A01, 19};

            backPage = 3;

            backNum = Va;

            setNum = tempoatual[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);

        }

        //Aajustar página de dados

        senão if(Va == 0x0400) //confirme

        {

            u16 switchpage[2] = {0x5A01, 0x0000};

            switchpage[1] = backPage;

            if(backPage == 1) //Retorna à página de status

            {

                placeGramNum = setNum;

                Write_Dgus(0x1140 + 0, placeGramNum% 10);

                Write_Dgus(0x1140 + 2, placeGramNum / 10% 10);

            }

            senão if(backPage == 3)

            {

                if(backNum >= 0x0304 && backNum <= 0x0309)

                {

                    u16 selecione = 0;

                    selecione = (backNum - 0x0304) * 0x10;

                    timrIntervalHour[backNum - 0x0304] = setNum;

                    Write_Dgus(0x3010 + selecione + 0, setNum% 10);

                    Write_Dgus(0x3010 + selecione + 2, setNum / 10% 10);

                }

                senão if(backNum >= 0x030A && backNum <= 0x030F)

                {

                    u16 selecione = 0;

                    selecione = (backNum - 0x0304) * 0x10;

                    currentTime[backNum - 0x030A] = setNum;

                    

                    if(backNum == 0x030A)

                    {

                        Write_Dgus(0x3010 + selecione + 0, setNum% 10);

                        Write_Dgus(0x3010 + selecione + 2, setNum / 10% 10);

                        Write_Dgus(0x3010 + selecione + 4, setNum / 100% 10);

                        Write_Dgus(0x3010 + selecione + 6, setNum / 1000% 10);

                    }

                    outro

                    {

                        Write_Dgus(0x3010 + selecione + 0, setNum% 10);

                        Write_Dgus(0x3010 + selecione + 2, setNum / 10% 10);

                    }

                }

            }

            write_dgus_vp(0x0084, switchpage, 2);

        }

        senão if(Va == 0x0401) //Voltar

        {

            u16 switchpage[2] = {0x5A01, 0x0000};

            switchpage[1] = backPage;

            write_dgus_vp(0x0084, switchpage, 2);

        }

        else if(Va == 0x0402) //Aumento numérico

        {

            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) //Diminuição numérica

        {

            if(definirNum > 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);

    }

}


Horário da postagem: 19 de setembro de 2023