README.md
1# Histreaming APP的智慧交通灯<a name="ZH-CN_TOPIC_0000001130176841"></a>
2## 硬件环境搭建
3- 硬件要求:Hi3861V100核心板、扩展板,OLED板,交通灯板;硬件搭建如下图所示。
4- [Hi3861V100核心板参考:HiSpark_WiFi_IoT智能开发套件_原理图硬件资料\原理图\HiSpark_WiFi-IoT_Hi3861_CH340G_VER.B.pdf](http://gitee.com/hihope_iot/embedded-race-hisilicon-track-2022/blob/master/%E7%A1%AC%E4%BB%B6%E8%B5%84%E6%96%99/HiSpark_WiFi_IoT%E6%99%BA%E8%83%BD%E5%AE%B6%E5%B1%85%E5%BC%80%E5%8F%91%E5%A5%97%E4%BB%B6_%E5%8E%9F%E7%90%86%E5%9B%BE.rar)
5- [扩展板参考:HiSpark_WiFi_IoT智能开发套件_原理图硬件资料\原理图\HiSpark_WiFi-IoT_Hi3861_CH340G_VER.B.pdf](http://gitee.com/hihope_iot/embedded-race-hisilicon-track-2022/blob/master/%E7%A1%AC%E4%BB%B6%E8%B5%84%E6%96%99/HiSpark_WiFi_IoT%E6%99%BA%E8%83%BD%E5%AE%B6%E5%B1%85%E5%BC%80%E5%8F%91%E5%A5%97%E4%BB%B6_%E5%8E%9F%E7%90%86%E5%9B%BE.rar)
6- [OLED板参考:HiSpark_WiFi_IoT智能开发套件_原理图硬件资料\原理图\HiSpark_WiFi_IoT_OLED_VER.A.pdf](http://gitee.com/hihope_iot/embedded-race-hisilicon-track-2022/blob/master/%E7%A1%AC%E4%BB%B6%E8%B5%84%E6%96%99/HiSpark_WiFi_IoT%E6%99%BA%E8%83%BD%E5%AE%B6%E5%B1%85%E5%BC%80%E5%8F%91%E5%A5%97%E4%BB%B6_%E5%8E%9F%E7%90%86%E5%9B%BE.rar)
7- [交通灯板硬件原理图参考:HiSpark_WiFi_IoT智能开发套件_原理图硬件资料\原理图\HiSpark_WiFi_IoT_SSL_VER.A.pdf](http://gitee.com/hihope_iot/embedded-race-hisilicon-track-2022/blob/master/%E7%A1%AC%E4%BB%B6%E8%B5%84%E6%96%99/HiSpark_WiFi_IoT%E6%99%BA%E8%83%BD%E5%AE%B6%E5%B1%85%E5%BC%80%E5%8F%91%E5%A5%97%E4%BB%B6_%E5%8E%9F%E7%90%86%E5%9B%BE.rar)
8
9
10
11## 软件介绍
12
13- 1.代码目录结构及相应接口功能介绍
14
15- WiFi API
16
17| API | 接口说明 |
18| ------------------------------------------------------------ | --------------------------------------- |
19| WifiErrorCode EnableWifi(void); | 开启STA |
20| WifiErrorCode DisableWifi(void); | 关闭STA |
21| int IsWifiActive(void); | 查询STA是否已开启 |
22| WifiErrorCode Scan(void); | 触发扫描 |
23| WifiErrorCode GetScanInfoList(WifiScanInfo* result, unsigned int* size); | 获取扫描结果 |
24| WifiErrorCode AddDeviceConfig(const WifiDeviceConfig* config, int* result); | 添加热点配置,成功会通过result传出netld |
25| WifiErrorCode GetDeviceConfigs(WifiDeviceConfig* result, unsigned int* size); | 获取本机所有热点配置 |
26| WifiErrorCode RemoveDevice(int networkId); | 删除热点配置 |
27| WifiErrorCode ConnectTo(int networkId); | 连接到热点 |
28| WifiErrorCode Disconnect(void); | 断开热点连接 |
29| WifiErrorCode GetLinkedInfo(WifiLinkedInfo* result); | 获取当前连接热点信息 |
30| WifiErrorCode RegisterWifiEvent(WifiEvent* event); | 注册事件监听 |
31| WifiErrorCode UnRegisterWifiEvent(const WifiEvent* event); | 解除事件监听 |
32| WifiErrorCode GetDeviceMacAddress(unsigned char* result); | 获取Mac地址 |
33| WifiErrorCode AdvanceScan(WifiScanParams *params); | 高级搜索 |
34
35- DHCP客户端接口:
36
37| API | 描述 |
38| ------------------- | ------------------ |
39| netifapi_netif_find | 按名称查找网络接口 |
40| netifapi_dhcp_start | 启动DHCP客户端 |
41| netifapi_dhcp_stop | 停止DHCP客户端 |
42
43- HiStreaming接口:
44
45| API | 描述 |
46| ------------------- | ------------------ |
47| LinkPlatformGe | 获得HiStreamingLinkLite组件对象 |
48| LinkPlatformFree | 释放HiStreamingLinkLite组件对象 |
49| LinkServiceAgentFree | 释放从设备列表中pop出来的LinkServiceAgent对象 |
50| LinkAgentGet | 获得LinkAgent对象 |
51| LinkAgentFree | 释放LinkAgent对象 |
52| QueryResultFree | 释放设备列表QueryResult。同时也释放设备列表关联的LinkServiceAgent对象 |
53
54- 2.工程编译
55 - 将源码./vendor/hisilicon/hispark_pegasus/demo目录下的histreaming_demo整个文件夹及内容复制到源码./applications/sample/wifi-iot/app/下。
56 ```
57 .
58 └── applications
59 └── sample
60 └── wifi-iot
61 └── app
62 └──histreaming_demo
63 └── 代码
64 ```
65
66 - 修改源码./applications/sample/wifi-iot/app/BUILD.gn文件,在features字段中增加索引,使目标模块参与编译。features字段指定业务模块的路径和目标,features字段配置如下。
67 ```
68 import("//build/lite/config/component/lite_component.gni")
69
70 lite_component("app") {
71 features = [
72 "histreaming_demo:appDemoTraffic",
73 ]
74 }
75 ```
76
77 - 修改.device/soc/hisilicon/hi3861v100/sdk_liteos/build/config/usr_config.mk文件。在这个配置文件中打开I2C,PWM驱动宏。搜索字段CONFIG_I2C_SUPPORT ,并打开I2C,PWM。配置如下:
78 ```
79 # CONFIG_I2C_SUPPORT is not set
80 CONFIG_I2C_SUPPORT=y
81 # CONFIG_PWM_SUPPORT is not set
82 CONFIG_PWM_SUPPORT=y
83 ```
84
85 - 工程相关配置完成后,然后rebuild编译。
86- 3.烧录
87 - 编译成功后,点击DevEco Home->配置工程->hi3861->upload_port->选择对应串口端口号->选择upload_protocol->选择hiburn-serial->点击save保存,在保存成功后点击upload进行烧录,出现connecting, please reset device..字样复位开发板等待烧录完成。
88 - 烧录成功后,再次点击Hi3861核心板上的“RST”复位键,此时开发板的系统会运行起来。
89- 4.手机端安装及使用([开发源码](https://gitee.com/leo593362220/shistreaming.git))
90
914.1 手机端安装HistreamingAPP,手机wifi连接Hi3861主板发射出来的热点。
92
934.2 打开HistreamingAPP,点击“局域网”,如果打开APP后没有马上出现“已绑定设备”,请往下滑不断刷新,直到出现绑定设备即可。
94
95 
96
974.3 点击“局域网”进去后,可以看到“Colorful_Light”、“Traffic_Light”等界面,点击app界面的“Traffic_Light”,进去之后可以看到“Control_Module”、“AutoModule”等,这时点击“Control_Module”,进去之后,连续点击button,即可看到控制设备侧的灯在切换。其他模式,用户可自行体验。其中点击“Return_Menu_Module”是返回主界面。
98
99
100
1014.4 实验结果:手机可以控制Hi3861V100实现三种交通灯模式切换,分别为Control Mode: 进入Traffic Light demo,初始状态就是Control Mode,是通过右边按键S2来控制红、黄、绿灯的亮灭状态不断切换。按键按下开启蜂鸣器,按键再次按下关闭;Auto Mode: 当按下左键S1时,会从control mode跳到Auto mode,交通灯模式,模仿交通灯,红灯常亮5秒,然后闪烁3秒,后黄灯闪烁3秒,后绿灯常亮5秒,再是绿灯闪烁3秒,如此循环,蜂鸣器开启后会响。最后一行的R,Y,G后面的数字代表倒数的时间,动态显示,时间的单位是秒,R代表红灯,Y代表黄灯,G代表绿灯,B代表的是蜂鸣器,数字“1”代表蜂鸣器打开状态,数字“0”代表蜂鸣器关闭状态。Human Mode: 当再次按下左键S1时,会从Auto mode跳到Human Mode模式,就是在Auto mode的基础上增加了人为控制,且红灯常亮改为30秒。模仿交通灯,红灯常亮30秒后闪烁3秒,黄灯闪烁3秒,然后绿灯常亮5秒,绿灯闪烁3秒,如此循环。如果按下右键S2,红灯立即快闪3秒,黄灯快闪3秒,进入绿灯常亮5秒,再绿灯闪烁3秒,后进入正常循环。蜂鸣器开启后会响。此时如果再按一下左键S1就会跳到Return Menu界面,选择按下Continue继续demo循环
102