3回答

1收藏

战舰V3通过ESP8266获得网络天气

机智云GoKit 机智云GoKit 5372 人阅读 | 3 人回复 | 2017-11-27

之前用8266和机智云成功通信了,见 帖子 http://club.gizwits.com/thread-8048-1-1.html  但是一直不知道8266是怎么设置联网,因为这个是下载的机智云的固件。后来就寻思着做了这个网络天气的。网上几乎没有人用STM32做天气的,基本上都是用arduino或者直接用esp8266+oled。

一、
硬件:战舰V3 + ESP8266 + 2.8寸屏
软件:1、esp8266的配置
         2、连接天气的服务器,get API数据
         3、cjson的移植与解析
         4、UTF8转GBK转码,这个网上很少例程
         5、图标的取模

   首先配置esp8266为透传模式


01

02

03

04

05

06

07

08

09

10

11

12

13

14

15

16

17

18

19

20

while(atk_8266_send_cmd("AT","OK",20))//?ì2éWIFI?£?éê?·??ú??
        {
                atk_8266_quit_trans();//í?3?í?′?
                atk_8266_send_cmd("AT+CIPMODE=0","OK",200);  //1?±?í?′??£ê?        
                Show_Str(40,55,200,16,"?′?ì2aμ??£?é!!!",16,0);
                delay_ms(800);
                LCD_Fill(40,55,200,55+16,WHITE);
                Show_Str(40,55,200,16,"3¢ê?á??ó?£?é...",16,0);
        }
        while(atk_8266_send_cmd("ATE0","OK",20));//1?±?????
        atk_8266_send_cmd("AT+CWMODE=1","OK",50);                //éè??WIFI STA?£ê?
        atk_8266_send_cmd("AT+RST","OK",20);                //DHCP·t???÷1?±?(??AP?£ê?óDD§)
        delay_ms(1000);         //?óê±3Sμè′y????3é1|
        delay_ms(1000);
        delay_ms(1000);
        delay_ms(1000);
        //éè??á??óμ?μ?WIFIí?????3?/?ó?ü·?ê?/?ü??,?a????2?êyDèòa?ù?Y?ú×??oμ??·óé?÷éè????DDDT??!!
        atk_8266_send_cmd("AT+CIPMUX=0","OK",20);   //0£oμ¥á??ó£?1£o?àá??ó
        sprintf((char*)p,"AT+CWJAP=\"%s\",\"%s\"",wifista_ssid,wifista_password);//éè???T??2?êy:ssid,?ü??
        while(atk_8266_send_cmd(p,"WIFI GOT IP",300));                                        //á??ó??±ê?·óé?÷,2¢?ò??μ?IP





然后连接天气服务器,get API


01

02

03

04

05

06

07

08

09

10

11

12

13

14

15

16

17

sprintf((char*)p,"AT+CIPSTART=\"TCP\",\"%s\",%s",WEATHER_SERVERIP,WEATHER_PORTNUM);    //??????±êTCP·t???÷
        res = atk_8266_send_cmd(p,"OK",200);//á??óμ???±êTCP·t???÷
        if(res==1)
        {
                myfree(SRAMIN,p);
                return 1;
        }
        delay_ms(300);
        atk_8266_send_cmd("AT+CIPMODE=1","OK",100);      //′?ê??£ê??a£oí?′?        
        atk_8266_get_wanip(ipbuf);//??è?WAN IP
        sprintf((char*)p,"IPμ??·:%s ???ú:%s",ipbuf,(u8*)WEATHER_PORTNUM);
//        Show_Str(30,65,200,12,p,12,0);                                //??ê?IPμ??·oí???ú        
        USART3_RX_STA=0;
        atk_8266_send_cmd("AT+CIPSEND","OK",100);         //?aê?í?′?
        printf("start trans...\r\n");

        u3_printf("GET [color=rgb(0, 130, 0) !important]https://api.seniverse.com);







然后再解析这个API返回的数据,并予以显示。

二、
1.目前免费的API有很多,我比较喜欢“心知天气”( https://www.seniverse.com/ )和 “和风天气”(http://www.heweather.com/  )。
  大家可以到这两个网站去注册,选择你们喜欢的天气API。心知天气的免费API返回的数据表少,功能较少。而和风天气的免费API则返回的比较详细。
  我这里选择心知天气,然后大家可以去看看心知天气的文档,里面有详细的数据结构(cjson数据)。
2.移植和解析cjson。
  这个东西很简单,我也是第一次移植,不过看了一篇教程就会了。推荐大家看下这两篇文章就可以了。
  http://blog.csdn.net/xukai871105/article/details/32346797    这个讲cjson的格式讲的蛮好的
  http://blog.csdn.net/lintax/article/details/50993958     这个讲cjson的使用
  https://sourceforge.net/projects/cjson/          这个网站是下载cjson的

  移植cjson,注意两点,一个是cjson占用堆比较大,大约3K,这个坑我就遇到了,使用默认的堆大小不能运行,于是我把堆改成了4K。




  第二点就是 要为 cjson 配置malloc ,打开cjson.c,修改下面几处。修改成原子的mymalloc,由于原子的mymalloc有个选择SRAMIN的参数,所以我又封装了下,弄了个my_malloc。
  



3.连接天气服务器,然后get 天气的api。
   这里卡了好半天,一开始用网口调试助手连上了服务器,然后get那个API链接的时候,一直不成功,原来是要在这个链接后面加两个回车,这个得感谢坛友  svwydh


4.解析天气数据
  用cjson库来解析天气数据,这里有个问题就是获得的天气数据的格式都是  utf8 的,无法直接显示在屏上,需要转码成GBK的,而原子哥的汉字例程就是gbk的。
  utf8转gbk这个网上也比较少,问了很多网友,有人说用查表法,于是又去找,侥幸找到了一个类似的,然后修改了下,居然可以用。


5.图标的制作
  首先自己去选一套漂亮的天气图标,我刚才推荐的那两个网站里已经为大家准备了图标,可自行下载。
  然后用战舰光盘里那个Image2lcd的软件,选择输出灰度为单色,这样取模以后的数据最小。打开你的天气图标,然后点保存,就可以保存为一个数组的c文件,将这个
  数组添加到你的工程里去。


大体上的难点和知识点就是上面这些。

上几张效果图。一张彩色的,一张白色的,大家觉得哪个好看点。


接下来传个演示视频由于视频不能播放,先放个链接:http://v.youku.com/v_show/id_XMz ... qq-pf-to=pcqq.group


如果大家感兴趣,将会上传源码。
@svwydh 感谢


以下是源码,喜欢的可自行下载。 ESP8266获取网络天气适配战舰V3.zip

分享到:
回复

使用道具 举报

回答|共 3 个

倒序浏览

沙发

yayasoso

发表于 2017-11-27 20:53:55 | 只看该作者

不错额,谢谢分享!
板凳

yayasoso

发表于 2017-11-27 20:54:26 | 只看该作者

代码怎么就是个图片呢?
地板

机智云

发表于 2017-12-6 15:25:19 | 只看该作者

yayasoso 发表于 2017-11-27 20:54
代码怎么就是个图片呢?

复制过来的。
你百度搜索一下标题,在opendv社区有原文
您需要登录后才可以回帖 注册/登录

本版积分规则

关闭

站长推荐上一条 /3 下一条