2014-11-13 00:17:08 +08:00
|
|
|
# **NodeMcu** #
|
|
|
|
###A lua based firmware for wifi-soc esp8266
|
2014-12-08 20:30:00 +08:00
|
|
|
version 0.9.2 build 2014-12-08
|
2014-11-18 01:27:46 +08:00
|
|
|
# Change log
|
2014-12-08 20:30:00 +08:00
|
|
|
2014-12-08<br />
|
|
|
|
add uart.setup(), uart.write() api.<br />
|
|
|
|
|
2014-12-07 12:21:24 +08:00
|
|
|
2014-12-07<br />
|
|
|
|
add ow(1-wire module), from arduino, and use same api.<br />
|
|
|
|
add an 18b20 1-wire example.<br />
|
2014-12-07 12:29:29 +08:00
|
|
|
change net.socket.send() payload max len from 256 to 1460.<br />
|
|
|
|
modify gpio.mode() api, add internal pullup/float para.
|
2014-11-29 01:48:22 +08:00
|
|
|
|
2014-11-29 01:45:54 +08:00
|
|
|
[more change log](https://github.com/nodemcu/nodemcu-firmware/wiki/nodemcu_api_en#change_log)<br />
|
|
|
|
[更多变更日志](https://github.com/nodemcu/nodemcu-firmware/wiki/nodemcu_api_cn#change_log)
|
2014-11-07 12:59:19 +08:00
|
|
|
# Summary
|
|
|
|
- Easy to access wireless router
|
2014-11-13 00:17:08 +08:00
|
|
|
- Based on Lua 5.1.4
|
|
|
|
- Event-Drive programming preferred.
|
2014-12-07 12:21:24 +08:00
|
|
|
- Build-in file, timer, pwm, i2c, 1-wire, net, gpio, wifi, adc, uart and system api.
|
2014-11-13 00:17:08 +08:00
|
|
|
- GPIO pin re-mapped, use the index to access gpio, i2c, pwm.
|
2014-11-10 21:00:17 +08:00
|
|
|
- GPIO Map Table:
|
2014-11-07 12:59:19 +08:00
|
|
|
|
|
|
|
<table>
|
|
|
|
<tr>
|
|
|
|
<th scope="col">IO index</th><th scope="col">ESP8266 pin</th><th scope="col">IO index</th><th scope="col">ESP8266 pin</th>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>0</td><td>GPIO12</td><td>8</td><td>GPIO0</td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>1</td><td>GPIO13</td><td>9</td><td>GPIO2</td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>2</td><td>GPIO14</td><td>10</td><td>GPIO4</td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>3</td><td>GPIO15</td><td>11</td><td>GPIO5</td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>4</td><td>GPIO3</td><td></td><td></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>5</td><td>GPIO1</td><td></td><td></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>6</td><td>GPIO9</td><td></td><td></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>7</td><td>GPIO10</td<td></td><td></td>
|
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
|
|
|
|
|
2014-11-13 00:17:08 +08:00
|
|
|
#Flash the firmware
|
|
|
|
nodemcu_512k.bin: 0x00000<br />
|
2014-12-05 15:57:34 +08:00
|
|
|
for most esp8266 modules, just pull GPIO0 down and restart.<br />
|
|
|
|
You can use the [nodemcu-flasher](https://github.com/nodemcu/nodemcu-flasher) to burn the firmware.
|
2014-11-11 12:31:45 +08:00
|
|
|
|
2014-11-13 00:17:08 +08:00
|
|
|
#Connect the hardware in serial
|
|
|
|
braudrate:9600
|
2014-11-11 12:31:45 +08:00
|
|
|
|
2014-11-13 00:17:08 +08:00
|
|
|
#Start play
|
2014-11-11 12:31:45 +08:00
|
|
|
|
2014-11-13 00:17:08 +08:00
|
|
|
####Connect to your ap
|
2014-10-13 20:24:52 +08:00
|
|
|
|
2014-11-13 00:17:08 +08:00
|
|
|
```lua
|
|
|
|
print(wifi.sta.getip())
|
|
|
|
--0.0.0.0
|
2014-11-07 12:59:19 +08:00
|
|
|
wifi.setmode(wifi.STATION)
|
2014-11-13 00:17:08 +08:00
|
|
|
wifi.sta.config("SSID","password")
|
2014-11-07 12:59:19 +08:00
|
|
|
print(wifi.sta.getip())
|
2014-11-13 00:17:08 +08:00
|
|
|
--192.168.18.110
|
2014-11-07 12:59:19 +08:00
|
|
|
```
|
2014-10-13 20:24:52 +08:00
|
|
|
|
2014-11-13 00:17:08 +08:00
|
|
|
####Manipulate hardware like a arduino
|
|
|
|
|
|
|
|
```lua
|
|
|
|
pin = 1
|
|
|
|
gpio.mode(pin,gpio.OUTPUT)
|
|
|
|
gpio.write(pin,gpio.HIGH)
|
|
|
|
print(gpio.read(pin))
|
2014-11-07 12:59:19 +08:00
|
|
|
```
|
2014-10-13 20:24:52 +08:00
|
|
|
|
2014-11-13 00:17:08 +08:00
|
|
|
####Write network application in nodejs style
|
|
|
|
|
|
|
|
```lua
|
|
|
|
-- A simple http client
|
2014-11-20 15:45:21 +08:00
|
|
|
conn=net.createConnection(net.TCP, 0)
|
2014-11-25 19:28:44 +08:00
|
|
|
conn:on("receive", function(conn, payload) print(payload) end )
|
2014-11-13 00:17:08 +08:00
|
|
|
conn:connect(80,"115.239.210.27")
|
|
|
|
conn:send("GET / HTTP/1.1\r\nHost: www.baidu.com\r\n"
|
|
|
|
.."Connection: keep-alive\r\nAccept: */*\r\n\r\n")
|
2014-11-07 12:59:19 +08:00
|
|
|
```
|
2014-10-13 20:24:52 +08:00
|
|
|
|
2014-11-13 00:17:08 +08:00
|
|
|
####Or a simple http server
|
|
|
|
|
|
|
|
```lua
|
|
|
|
-- A simple http server
|
|
|
|
srv=net.createServer(net.TCP)
|
|
|
|
srv:listen(80,function(conn)
|
|
|
|
conn:on("receive",function(conn,payload)
|
|
|
|
print(payload)
|
|
|
|
conn:send("<h1> Hello, NodeMcu.</h1>")
|
|
|
|
end)
|
2014-11-22 21:24:51 +08:00
|
|
|
conn:on("sent",function(conn) conn:close() end)
|
2014-11-13 00:17:08 +08:00
|
|
|
end)
|
|
|
|
```
|
|
|
|
|
|
|
|
####Do something shining
|
|
|
|
```lua
|
|
|
|
function led(r,g,b)
|
|
|
|
pwm.setduty(0,r)
|
|
|
|
pwm.setduty(1,g)
|
|
|
|
pwm.setduty(2,b)
|
|
|
|
end
|
2014-11-29 23:33:45 +08:00
|
|
|
pwm.setup(0,500,512)
|
|
|
|
pwm.setup(1,500,512)
|
|
|
|
pwm.setup(2,500,512)
|
2014-11-13 00:17:08 +08:00
|
|
|
pwm.start(0)
|
|
|
|
pwm.start(1)
|
|
|
|
pwm.start(2)
|
2014-11-29 23:33:45 +08:00
|
|
|
led(512,0,0) -- red
|
|
|
|
led(0,0,512) -- blue
|
2014-11-13 00:17:08 +08:00
|
|
|
```
|
|
|
|
|
|
|
|
####And blink it
|
|
|
|
```lua
|
|
|
|
lighton=0
|
|
|
|
tmr.alarm(1000,1,function()
|
|
|
|
if lighton==0 then
|
|
|
|
lighton=1
|
2014-11-29 23:33:45 +08:00
|
|
|
led(512,512,512)
|
2014-11-13 00:17:08 +08:00
|
|
|
else
|
|
|
|
lighton=0
|
|
|
|
led(0,0,0)
|
|
|
|
end
|
|
|
|
end)
|
|
|
|
```
|
|
|
|
|
|
|
|
####If you want to run something when system started
|
|
|
|
```lua
|
|
|
|
--init.lua will be excuted
|
|
|
|
file.open("init.lua","w")
|
|
|
|
file.writeline([[print("Hello, do this at the beginning.")]])
|
|
|
|
file.close()
|
|
|
|
node.restart() -- this will restart the module.
|
|
|
|
```
|
2014-11-18 19:58:48 +08:00
|
|
|
|
|
|
|
####With below code, you can telnet to your esp8266 now
|
|
|
|
```lua
|
|
|
|
-- a simple telnet server
|
2014-11-22 21:24:51 +08:00
|
|
|
s=net.createServer(net.TCP,180)
|
2014-11-18 19:58:48 +08:00
|
|
|
s:listen(2323,function(c)
|
|
|
|
function s_output(str)
|
2014-11-22 21:24:51 +08:00
|
|
|
if(c~=nil)
|
|
|
|
then c:send(str)
|
2014-11-18 19:58:48 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
node.output(s_output, 0) -- re-direct output to function s_ouput.
|
|
|
|
c:on("receive",function(c,l)
|
|
|
|
node.input(l) -- works like pcall(loadstring(l)) but support multiple separate line
|
|
|
|
end)
|
|
|
|
c:on("disconnection",function(c)
|
|
|
|
node.output(nil) -- un-regist the redirect output function, output goes to serial
|
|
|
|
end)
|
2014-11-22 21:24:51 +08:00
|
|
|
print("Welcome to NodeMcu world.")
|
2014-11-18 19:58:48 +08:00
|
|
|
end)
|
|
|
|
```
|
2014-11-13 00:17:08 +08:00
|
|
|
#Check this out
|
2014-11-13 00:19:26 +08:00
|
|
|
Tencent QQ group: 309957875<br/>
|
2014-11-21 00:10:01 +08:00
|
|
|
[nodemcu wiki](https://github.com/nodemcu/nodemcu-firmware/wiki)<br/>
|
2014-11-18 01:24:49 +08:00
|
|
|
[nodemcu.com](http://www.nodemcu.com)
|