“Microduino ENC网络(七)/zh”的版本间的差异

来自Microduino Wikipedia
跳转至: 导航搜索
原理图
原理图
 
(未显示2个用户的5个中间版本)
第1行: 第1行:
 +
{{Language | Microduino_ENC_Network_(7)}}
 
{| style="width: 800px;"
 
{| style="width: 800px;"
 
|-
 
|-
第6行: 第7行:
  
 
==设备==
 
==设备==
*'''[[Microduino-Core]]'''
+
*'''[[Microduino-Core/zh]]'''
*'''[[Microduino-FT232R]]'''
+
*'''[[Microduino-USBTTL/zh]]'''
*'''[[Microduino-ENC28J60]]'''
+
*'''[[Microduino-ENC28J60/zh]]'''
*'''[[Microduino-RJ45]]'''
+
*'''[[Microduino-RJ45/zh]]'''
  
 
*其他硬件设备
 
*其他硬件设备
**USB数据连接线  一根  
+
**USB数据连接线  一根
  
 
==一些HTML==
 
==一些HTML==
第34行: 第35行:
 
*Microduino-RJ45
 
*Microduino-RJ45
 
*Microduino-Core
 
*Microduino-Core
*Microduino-FT232R
+
*Microduino-USBTTL
 
层层堆叠,再插上网线。
 
层层堆叠,再插上网线。
  
 
如下图所示:
 
如下图所示:
[[File:MicroduinoENCLED.jpg|600px|center|thumb]]
+
[[File:MicroduinoENCLED1.jpg|600px|center|thumb]]
  
 
==程序==
 
==程序==
  
ENCnetworkseven
+
[https://github.com/Microduino/Microduino_Tutorials/tree/master/Microduino_ENC/ENCnetworkseven ENCnetworkseven]
 
 
  
 
==调试==
 
==调试==

2015年1月27日 (二) 12:36的最新版本

Language English

目的

本教程将教大家如何用web浏览器来控制Microduino,从而控制一个led。

设备

  • 其他硬件设备
    • USB数据连接线 一根

一些HTML

先来了解一下HTML,当你的浏览器请求Microduino时,它会向你的浏览器发送如下图的HTML:

Htmlcode.jpg

上图绿色为HTML部分,显示的是Led的实际工作状态和一个按钮来改变它。

从HTML页面的源代码我们可以找到变量的元素,即根据Led状态来改变的元素。

从代码中,我们还可以了解,当用户单击按钮时发生了什么事情:浏览器会请求Microduino如下页面。

  • /?status=ON,如果我们要打开Led;
  • /?status=OFF,如果我们要关闭Led。

name=value它的作用是通过GET方法向web服务器发送一个标准的表单。

原理图

  • Microduino-ENC28J60
  • Microduino-RJ45
  • Microduino-Core
  • Microduino-USBTTL

层层堆叠,再插上网线。

如下图所示:

MicroduinoENCLED1.jpg

程序

ENCnetworkseven

调试

步骤一:首先需要下载EtherCard库:https://github.com/jcw/ethercard

放到你的IDE的libraries文件夹中,重启IDE。

步骤二:解释一下代码:

//定义了2个静态字符串(ON,OFF)和2个字符串变量,字符串变量将用来创建HTML页面,将2个静态字符串之一赋值给这2个变量。

   char* on = "ON";
   char* off = "OFF";
   char* statusLabel;

  char* buttonLabel;

//在setup()除了EtherCard库设置,还要配置Led的初始状态(off)。

     pinMode(ledPin, OUTPUT);
     digitalWrite(ledPin, LOW);
     ledStatus = false;

//在主loop(),我们的代码解析浏览器的请求(存储在Ethernet::buffer缓存从pos开始的位置),寻找状态ON/OFF命令。

       if(strstr((char *)Ethernet::buffer + pos, "GET /?status=ON") != 0) {
         Serial.println("Received ON command");
         ledStatus = true;
       }
       if(strstr((char *)Ethernet::buffer + pos, "GET /?status=OFF") != 0) {
         Serial.println("Received OFF command");
         ledStatus = false;
       }

//更新ledPin(Arduino与Led相连的端口)状态,把statusLabel与buttonLabel两个变量关联到正确的标签。

       if(ledStatus) {
         digitalWrite(ledPin, HIGH);
         statusLabel = on;
         buttonLabel = off;
       } else {
         digitalWrite(ledPin, LOW);
         statusLabel = off;
         buttonLabel = on;
       }

步骤三:连接好灯泡,如下图:

ConnectLED.jpg


步骤四:下载代码并编译通过。

步骤五:用浏览器访问Microduino的IP地址后,点击页面上的ON/OFF,看看灯泡有啥反应。


结果

访问你的Microduino IP地址,如果能看到如下界面:

LEDWebPage.jpg

你就可以用浏览器控制灯泡了。

视频

http://v.youku.com/v_show/id_XNzAzMzM0NzUy.html