Difference between revisions of "Component: WIFI (BL0136) (E-blocks 2)"
| Line 117: | Line 117: | ||
| {{Fcfile|NetworkComms-ESP8266-Server.fcfx|NetworkComms ESP8266 Webserver}} | {{Fcfile|NetworkComms-ESP8266-Server.fcfx|NetworkComms ESP8266 Webserver}} | ||
| + | |||
| + | |||
| Line 122: | Line 124: | ||
| ==Macro reference== | ==Macro reference== | ||
| + | ===SendString=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 145: | Line 148: | ||
| + | ===DisconnectFromSSID=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 158: | Line 162: | ||
| + | ===ClientConnect=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 186: | Line 191: | ||
| + | ===ControlTCPServer=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 209: | Line 215: | ||
| + | ===GetFirmwareVersion=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 222: | Line 229: | ||
| + | ===CheckForPageRequests=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 235: | Line 243: | ||
| + | ===ClientSendRequest=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 253: | Line 262: | ||
| + | ===ReadSSIDFromScan=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 271: | Line 281: | ||
| + | ===CreateAccessPoint=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 304: | Line 315: | ||
| + | ===SetOutValue=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 327: | Line 339: | ||
| + | ===EndServerConnection=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 340: | Line 353: | ||
| + | ===Send_Embedded_HTML_Page4=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 353: | Line 367: | ||
| + | ===ReadSignalStrengthFromScan=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 371: | Line 386: | ||
| + | ===Send_Embedded_HTML_Page3=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 384: | Line 400: | ||
| + | ===Send_Embedded_HTML_Page2=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 397: | Line 414: | ||
| + | ===Send_Embedded_HTML_Page1=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 410: | Line 428: | ||
| + | ===ReadEncryptionModeFromScan=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 428: | Line 447: | ||
| + | ===GetByteWithTimeout=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 441: | Line 461: | ||
| + | ===GetInValue=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 459: | Line 480: | ||
| + | ===ConnectToSSID=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 487: | Line 509: | ||
| + | ===ClientSendArray=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 510: | Line 533: | ||
| + | ===GetRxArray=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 533: | Line 557: | ||
| + | ===ScanForSSID=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 546: | Line 571: | ||
| + | ===Initialise=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
| Line 559: | Line 585: | ||
| + | ===CheckTCPServerIP=== | ||
| {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | {| class="wikitable" style="width:60%; background-color:#FFFFFF;" | ||
| |- | |- | ||
Revision as of 11:49, 3 February 2023
| Author | Matrix Ltd. | 
| Version | 2.1 | 
| Category | E-blocks 2 | 
Contents
- 1 WIFI component
- 2 Component Source Code
- 3 Detailed description
- 4 Examples
- 5 Macro reference
- 5.1 SendString
- 5.2 DisconnectFromSSID
- 5.3 ClientConnect
- 5.4 ControlTCPServer
- 5.5 GetFirmwareVersion
- 5.6 CheckForPageRequests
- 5.7 ClientSendRequest
- 5.8 ReadSSIDFromScan
- 5.9 CreateAccessPoint
- 5.10 SetOutValue
- 5.11 EndServerConnection
- 5.12 Send_Embedded_HTML_Page4
- 5.13 ReadSignalStrengthFromScan
- 5.14 Send_Embedded_HTML_Page3
- 5.15 Send_Embedded_HTML_Page2
- 5.16 Send_Embedded_HTML_Page1
- 5.17 ReadEncryptionModeFromScan
- 5.18 GetByteWithTimeout
- 5.19 GetInValue
- 5.20 ConnectToSSID
- 5.21 ClientSendArray
- 5.22 GetRxArray
- 5.23 ScanForSSID
- 5.24 Initialise
- 5.25 CheckTCPServerIP
 
- 6 Property reference
WIFI component
Wireless LAN component designed to work with the ESP-12S module. Provides a very simple interface to allow webpages to be hosted from hardware or simulation. Also available in the form of the BL0136 WIFI E-block.
Component Source Code
Please click here to download the component source project: FC_Comp_Source_EBlocks2_WLAN_ESP12S_BL0136.fcfx
Please click here to view the component source code (Beta): FC_Comp_Source_EBlocks2_WLAN_ESP12S_BL0136.fcfx
Detailed description
No detailed description exists yet for this component
Examples
The examples below are all done using a EB091 board as the host
The EB069 ESP8266 Wifi E-block is connected to PORTD 0-7 with the patch setting set to B.
The EB005 LCD E-block is connected to PORTB 0-7 with the patch setting set to Default.
Other host boards are compatible with the examples, simply change the target chip and component connection properties.
Firmware Test
This example collects the firmware version from the ESP8266 module and displays it on an LCD. Tested working with firmware version 00150900.
Wireless Scanner
This example scans for wireless networks in range and prints the network IDs to the LCD along with the signal strength and security type.
Creating An Access Point
This example creates an access point you can connect your phone or laptop to named Flowcode_ESP8266. The password to connect to the access point is flowcode6.
Note this example simply creates an access point, no data is transferred.
Joining An Access Point
This example joins an existing access point. The network ID and Password must be altered to match your local WIFI network settings.
Note this example simply joins an access point, no data is transferred.
TCP Client
This example joins an existing access point. The network ID and Password must be altered to match your local WIFI network settings.
Once joined to the network the example connects to the MatrixTSL website and requests a file which is printed out on the LCD.
TCP Server
This example creates an access point you can connect your phone or laptop to named Flowcode_ESP8266. The password to connect to the access point is flowcode6.
Once the access point is created the example shows the server IP address on the LCD. Connecting to the wireless network on your phone or laptop and visiting the IP address shown on the LCD using a web browser allows you to switch LED outputs on and off.
Network Comms
Here are some examples using the Network Communication component linked to the ESP8266 component.
 NetworkComms ESP8266 Webserver
NetworkComms ESP8266 Webserver
Macro reference
SendString
DisconnectFromSSID
|   | DisconnectFromSSID | 
| Disconnects from the current SSID. Returns 1 if the command was accepted and returned an "OK" | |
|  - BYTE | Return | 
ClientConnect
ControlTCPServer
GetFirmwareVersion
|   | GetFirmwareVersion | 
| Collects the firmware version from the ESP8266 module and returns it as a string. | |
|  - STRING | Return | 
CheckForPageRequests
|   | CheckForPageRequests | 
| To be called periodically. Returns non-zero if a request has been processed | |
|  - BYTE | Return | 
ClientSendRequest
|   | ClientSendRequest | 
| Sends out a string with the required AT+CIPSEND=Length$(Request) initialiser. | |
|  - STRING | Request | 
| e.g. "GET / HTTP/1.0\r\n\r\n" | |
|  - VOID | Return | 
ReadSSIDFromScan
|   | ReadSSIDFromScan | 
| Collects one of the SSID name strings from the last SSID Scan. The ScanForSSID macro must be called first. | |
|  - BYTE | Index | 
| SSID Index | |
|  - STRING | Return | 
CreateAccessPoint
SetOutValue
|   | SetOutValue | 
| Set the value of an outbound substitution string | |
|  - BYTE | index | 
| Range 0-4 | |
|  - STRING | value | 
|  - VOID | Return | 
EndServerConnection
|   | EndServerConnection | 
| Disconnects from the current active TCP/IP pipe. | |
|  - BYTE | Return | 
Send_Embedded_HTML_Page4
|   | Send_Embedded_HTML_Page4 | 
|  - VOID | Return | 
ReadSignalStrengthFromScan
Send_Embedded_HTML_Page3
|   | Send_Embedded_HTML_Page3 | 
|  - VOID | Return | 
Send_Embedded_HTML_Page2
|   | Send_Embedded_HTML_Page2 | 
|  - VOID | Return | 
Send_Embedded_HTML_Page1
|   | Send_Embedded_HTML_Page1 | 
|  - VOID | Return | 
ReadEncryptionModeFromScan
GetByteWithTimeout
|   | GetByteWithTimeout | 
| Attempts to receive a byte from the circular buffer. If nothing is available then waits up to 200 ms for data to become available. | |
|  - BYTE | Return | 
GetInValue
|   | GetInValue | 
| Returns the string value of a Request parameter | |
|  - BYTE | index | 
| Index of the request paramter, starting at zero Range 0-2 | |
|  - STRING | Return | 
ConnectToSSID
ClientSendArray
|   | ClientSendArray | 
| Sends out an array of data bytes with the required AT+CIPSEND=Length$(Request) initialiser. | |
|  - BYTE | Data | 
|  - UINT | NumBytes | 
|  - VOID | Return | 
GetRxArray
ScanForSSID
Initialise
|   | Initialise | 
| Initialise the device with the property data. Returns 1 if "ready" message successfully received Returns 0 if no reply from module | |
|  - BYTE | Return | 
CheckTCPServerIP
|   | CheckTCPServerIP | 
| Collects the local IP address of the active TCP server. | |
|  - STRING | Return | 









