【开源获奖案例】基于T5L的smtp邮件发送器

——来自迪文开发者论坛

     本期为您推送一个非常实用的迪文开发者论坛获奖开源案例——基于T5L的smtp邮件发送器。工程师采用T5L智能屏,通过WiFi模块访问smtp服务器,实现了发送邮件给管理员的功能,操作时在屏幕上输入收件人邮箱、邮件标题、邮件内容等信息即可。值得注意的是,邮件内容还支持纯文本、组态控件、设置文本颜色等编辑方式。

一、演示视频

             操作示例

     完整开发资料含迪文屏DGUS工程资料与代码,可前往迪文开发者论坛获取。

  二、 方案简介  

方案架构

      T5L智能屏通过串口5控制WiFi模块与smtp服务器交互,实现邮件发送功能。

界面开发

      DGUS软件通过图层叠加来完成显示和触控功能开发,用户只需要把准备好的图片素材加载到DGUS软件,设置好显示和触控功能即可。

C51软件设计

      T5L智能屏串口5与WiFi模块通讯,完成与smtp服务器交互。完整代码请参考源码工程,部分主要代码如下:

void uart5_init(u32 baud)

{

    SCON3T = 0x80;

    SCON3R = 0x80;

    baud = (u32)((double)(FOSC/8.0)/baud);

    BODE3_DIV_H = (baud>>8)&0xff;

    BODE3_DIV_L = baud&0xff;

    ES3R = 0;

    ES3T = 0;

}

void u5_send_byte(u8 byte)

{

    SBUF3_TX = byte;

    while(!(SCON3T&0x01));

    SCON3T &= 0xfe;

}

void u5_send_bytes(u8 *bytes,u16 len)

{

    u16 i;

    for(i=0;i<len;i++)

    {

        SBUF3_TX = bytes;

        while(!(SCON3T&0x01));

        SCON3T &= 0xfe;

    }

}

void get_input(u8 * val,u8 len)

{

    u8 i;

    for(i=0;i<len;i++)

    {

        if(val==0xff)

        {

            val = 0x00;

            val[i+1] = 0x00;

            return;

        }

    }

}

u8 esp8266_send_cmd(u8 *cmd,u8 *ack,u16 waittime,u8 clearBuffer)

{

    u8 res=0;

    rx_sta=0;

    if(ack&&waittime&&cmd)       

    {

        while(--waittime)       

        {

            sys_delay_ms(10);

            if(rx_sta&0X8000)

            {

                if(esp8266_check_respond(ack))

                break;

            }

        }

        if(waittime==0)res=1;

        if(clearBuffer==1)rx_sta=0;

    }

    return res;

}

typedef struct{

    u8 cmd;

    u8 email[20];

    u8 name[20];

    u8 title[20];

    u8 msg[60];

}EMAIL_INFO;

EMAIL_INFO email_info;

u8 respond[80];

u8 wifi_name[30];

u8 wifi_passwd[30];

u8 server[30];

u8 port[30];

u8 username[30];

u8 auth_code[30];

u8 rx_sta;

sys_read_vp(0x1000,(u8*)&btn_val,1);

if(btn_val)

{

    if(btn_val==1)

    {

        sys_read_vp(0x3000,email_info.name,10);

        sys_read_vp(0x3020,email_info.email,10);

        sys_read_vp(0x3040,email_info.title,10);

        sys_read_vp(0x3060,email_info.msg,30);

        get_input(email_info.name,20);

        get_input(email_info.email,20);

        get_input(email_info.title,20);

        get_input(email_info.msg,60);

        send_packet((u8*)&email_info,sizeof(EMAIL_INFO));

        if(rx_sta)

            send_mail(email_info.email,email_info.title,email_info.msg);

    }else if(btn_val==2)

    {

        sys_read_vp(0x3100,wifi_name,15);

        sys_read_vp(0x3120,wifi_passwd,15);

        get_input(wifi_name,30);

        get_input(wifi_passwd,30);

    }else if(btn_val==3)

    {

        sys_read_vp(0x3200,server,15);

        sys_read_vp(0x3220,port,15);

        sys_read_vp(0x3240,username,15);

        sys_read_vp(0x3260,auth_code,15);       

        get_input(server,30);

        get_input(port,30);

        get_input(username,30);

        get_input(auth_code,30);                               

    }

    btn_val = 0;

    sys_write_vp(0x1000,(u8*)&btn_val,1);

}

sys_read_vp(0x2050,(u8*)&btn_val2,1);

if(btn_val2!=old_val)

{

    if(btn_val2==1)

        sys_write_vp(0x3060,"This is a email from T5L!\0\0",30);

    else if(btn_val2==2)

        sys_write_vp(0x3060,"<button>Click</button><br><br><inputvalue='good'>\0\0",30);

    else if(btn_val2==3)

        sys_write_vp(0x3060,"<h3>Bold</h3>

<h1 style='color:red;'>Red</h1>\0\0",30);

    old_val = btn_val2;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 基于Vue开发的组态编辑器已经有很多开源项目可以使用。Vue是一种流行的JavaScript框架,适用于构建现代且高效的用户界面。 组态编辑器是一种可以帮助开发人员和设计师创建和编辑用户界面的工具。它通常提供了一个可视化界面,允许用户拖放和配置各种组件,并生成相应的代码。 通过使用Vue,开源的组态编辑器可以充分利用Vue的特性。Vue的组件化架构使得创建和嵌套组件变得非常容易,这使得组态编辑器可以提供丰富的组件库以及快速配置和编辑的功能。 这些开源的基于Vue的组态编辑器提供了灵活的自定义选项,可以根据用户的需求进行扩展和定制。通过使用Vue的生态系统中的其他工具和库,如Vuex和Vue Router,组态编辑器可以实现更复杂的功能,如状态管理和路由。 开源的组态编辑器项目还提供了强大的社区支持。开发者可以从其他用户的经验中获益,找到解决问题的方法,并与其他人共享自己的成果。 总之,基于Vue开发的开源组态编辑器是一个非常有用的工具,可以帮助开发人员和设计人员更轻松地创建和编辑用户界面。它利用了Vue的特性和生态系统,并通过强大的社区支持提供了一个简单而灵活的解决方案。 ### 回答2: 基于Vue开发的组态编辑器是一种用于创建、编辑和管理可视化组态的开源工具。它是使用Vue框架开发的,通过Vue的响应式数据绑定、组件化和虚拟DOM等特性,具备高效、灵活和可扩展的特点。 作为一个开源项目,基于Vue开发的组态编辑器允许用户自由使用、修改和分发。这意味着用户可以根据自己的需求自定义组态编辑器的功能、扩展其特性,甚至与其他项目进行集成。这种开源的特性使得组态编辑器具有更高的可定制性和可持续性。 基于Vue开发的组态编辑器不仅可以用于创建静态的组态界面,还可以通过各种交互元素(如按钮、输入框等)实现动态的组态效果。它提供了丰富的组件库,包括图表、控件、容器等,用户可以直接拖拽并配置这些组件来构建自己的组态界面。同时,组态编辑器还支持导入、导出组态配置,方便用户在不同项目之间进行共享和迁移。 基于Vue的组态编辑器具有良好的用户界面和用户体验,通过直观的操作和友好的设计,使用户能够轻松地创建、编辑和管理组态界面。它还提供了丰富的文档和示例,帮助用户快速上手并掌握使用技巧。 总之,基于Vue开发的组态编辑器是一个功能丰富、高度可定制和易于使用的开源工具,可以帮助开发者高效地创建和管理可视化组态界面。无论是个人开发者还是企业项目,都可以从中受益并加速开发进程。 ### 回答3: 基于Vue开发的组态编辑器目前是开源的。组态编辑器是一种可帮助用户设计和配置工控系统界面的工具,Vue作为一种流行的JavaScript框架,在开发过程中提供了诸多便利和灵活性。 开源的组态编辑器可以使用户更容易地创建和定制工控系统界面。它提供了一套易于使用和交互友好的界面组件,可以方便地拖拽、缩放和配置,以实现个性化的界面设计。用户可以根据需求自定义各种组件的样式、布局和交互行为。 基于Vue框架的组态编辑器还具备一些高级功能,如数据绑定和响应式设计。它可以与后端服务器进行数据交互,实现动态的数据展示和更新。同时,在用户修改界面配置时,可以实时反映在界面上,减少开发者的调试时间。 由于是开源的,组态编辑器还具备扩展性和可定制性。开发者可以根据自己的需求进行二次开发和定制,添加新的功能或者修改现有功能。同时,开源社区的积极参与也可以提供更多的插件和扩展,丰富组态编辑器的功能。 总的来说,基于Vue开发的组态编辑器具有易用性、灵活性和扩展性等优势。它为用户提供了一种方便快捷的方式来设计和定制工控系统界面,帮助用户实现个性化的界面配置。开源的特性也使得组态编辑器可以更好地适应不同的需求,并获得更多的改进和支持。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值