很多用户拿到板子以后说没有资料。在此再次公开下eBox生态圈的技术群:139218853群里有所有的资料。上传下教程:源码:源码不断更新最新下载地址:https://github.com
2015-12-14 13:47
`硬件【ebox生态圈】技术支持群:139218853Spark为STM32主板SPARK是基于STM32F103C8T6的控制板,作为eBox入门级的控制板,主要起到引导用户熟悉eBox固件库
2015-12-15 16:30
Spark详解(一):Spark及其生态圈概述
2019-06-21 16:45
`这个互联网的年代,如果你不支持物联网就不要出来混啦!科普:MQTT(Message Queuing Telemetry Transport,消息队列遥测传输)是IBM开发的一个即时通讯协议,将成为物联网的重要组成部分。该协议支持所有平台,几乎可以把所有联网物品和外部连接起来,被用来当做传感器和致动器(比如通过Twitter让房屋联网)的通信协议。MQ 遥测传输 (MQTT) 是轻量级基于代理的发布/订阅的消息传输协议,设计思想是开放、简单、轻量、易于实现。这些特点使它适用于受限环境。例如,但不仅限于此:●网络代价昂贵,带宽低、不可靠。●在嵌入设备中运行,处理器和内存资源有限。该协议的特点有:使用发布/订阅消息模式,提供一对多的消息发布,解除应用程序耦合。●对负载内容屏蔽的消息传输。●使用 TCP/IP 提供网络连接。●有三种消息发布服务质量: ▲“至多一次”,消息发布完全依赖底层 TCP/IP 网络。会发生消息丢失或重复。这一级别可用于如下情况,环境传感器数据,丢失一次读记录无所谓,因为不久后还会有第二次发送。 ▲“至少一次”,确保消息到达,但消息重复可能会发生。 ▲“只有一次”,确保消息到达一次。这一级别可用于如下情况,在计费系统中,消息重复或丢失会导致不正确的结果。●小型传输,开销很小(固定长度的头部是 2 字节),协议交换最小化,以降低网络流量。●使用 Last Will和 Testament 特性通知有关各方客户端异常中断的机制。库文件:Embedded MQTT C/C++ Client Libraries版本:移植的是目前最新稳定版本3.1.1下载地址:http://git.eclipse.org/c/paho/org.eclipse.paho.mqtt.embedded-c.git/refs/在此网页的左下角有三个下载链接,文件格式不同而已,选择第一个。移植简介:初看MQTT库文件觉得不知道从哪里下手。第一步就是选取自己需要的文件,解压后会看到MQTTPacket文件夹,移植到新的平台,这个文件夹就够用了。MQTTClient这个文件夹下面有已经移植好的接口,是在Linux、arduino、mbed平台上运行的。没有支持eBox,说明eBox还不够火,那咱们就自己移植吧。MQTTPacket文件夹下面有src文件夹。这个就是MQTT的核心代码,不用,也不要做任何修改。Samples文件夹下面的transport.c和.h是MQTT的基本数据传输函数。老外做的就是好,接口文件完全独立于本身的逻辑部分。transport.c这个文件就是移植的最重要部分!要实现基本的四个函数,只填充发送、接收、打开、关闭,不要对函数名称做任何修改,除了这四个函数外,用户也可以添加自己的接口,比如状态判断,需要初始化的东西。在eBox平台下,我吧transport.c改为.cpp,这要做是为了能让他使用eBox自带的tcp协议,而不必再去基于socket实现传输函数的移植。这一步大大的简化了填充过程。上代码:#include "tcp.h"TCPCLIENT mqtt_tcp;int transport_init(int local_sock,int local_port){ mqtt_tcp.begin(local_sock,local_port); return 0;}int transport_sendPacketBuffer(unsigned char* buf, int buflen){int rc = 0; rc = mqtt_tcp.send(buf,buflen);return rc;}int transport_getdata(unsigned char* buf, int count){return mqtt_tcp.recv(buf,count);}int transport_open(char* addr, int port){ return mqtt_tcp.connect((unsigned char *)addr,port);}int transport_close(int sock){ mqtt_tcp.stop();return 1;}int transport_connnected(){ return mqtt_tcp.is_connected();}不知道为什么一加注释代码就显示不全了。可以看源文件来查看详细内容写完这几个函数就可以,看官方提供的例程了。例程在samples文件夹下面。pub0sub1.c/qos0sub.c/pub0sub1_nb.c。打开之后,直接懵了。。。。。。。这是什么代码啊。。。沉下心来,过一遍就能理解个大概了。多过几遍就没问题了。从这几个例程中了解他的一个基本的通信过程。然后把他这些例程,移植到eBox上就行了。这里要注意的是,官方默认为你的接收函数使用阻塞式接收,而我用的是非阻塞的,要再应用层上做点循环,do ...while。先一直publish。调试协议多了,就会明白发送是一个比接收容易一百倍的事情。过了一天,调通了。。。然后移植接收,又是一天。然后就是优化,两天时间。应用层的移植过程中还需要不断的修改底层的函数bug,中间找到了不少网卡和socket的bug。所以花了比较长的时间。涉及的内容太多,就不贴出来了,看附件就行了。到此基本上实现了mqtt的qos0模式的发布和订阅消息。实现了断线自动重连。我用了两个eBox的板子,一个发布消息,一个订阅消息,运行一个晚上,第二天依然工作。没有断线。强势插入两个图片发布消息,每隔一段时间会给服务器发一个ping_req告诉服务器我还活着。。。订阅消息,当服务器向订阅者发布消息后,订阅者接收消息并显示。每隔一段时间会给服务器发一个ping_req告诉服务器我还活着。。。调试工具:http://m2m.demos.ibm.com/mqttclient/#subscribe怎么是个网页呢?鄙人不会各种高大上的软件平台,就找到了网页版的客户端,然后通过他来调试自己发送的数据,接收的数据。还有一个eclipse平台的服务器m2m.eclipse.org,1883端口可以让用户调试。移植好的文件,里面有mqtt的src文件和我自己的interface文件夹(包含了transport和应用层api)。用户把此文件夹放到eBox工程目录下的network文件夹下面。然后把代码添加到ebox工程中就可以了。两个API的使用例程上传一个3.1.1的协议说明,中文版最后上传下MQTT的全部文件重磅资料,最新的ebox固件库。。。。。。。。。。。。。。。。。。。等众筹结束后我会将整套工程,发布出来,让用户的编程变得简单再简单!!!希望朋友多多支持!我的众筹项目地址:http://z.elecfans.com/30.html 期待大家一起来完善和发展eBox,打造国人自己的库,不仅仅支持STM32,更能支持飞思卡尔MCU、NXP MCU······`
2015-11-24 00:19
串口在嵌入式设备中无疑是排在第一位的调试、输入输出接口!STM32中的串口应用起来比较简单,代码量不太复杂。但是一般用户的设计都是使用最基本的功能没有完全发挥串口硬件的功能,使得串口这个低速设备,严重影响了32的性能。一般情况下,使用串口的发送会浪费掉CPU的大量时间,到底有多大,你自己可以算算。为了解决这个问题eBox使用DMA来实现异步执行,使得单片机即使在没有操作系统的情况下也大大提高效率。此处讲解下异步执行的概念,当用户需要通过串口发送数据的时候,用户只需要将数据填充到发送缓冲区(指DMA发送缓冲区),然后开启DMA发送。MCU的任务就完成了,不用做任何等待就可以继续执行其他任务。这是,真正的发送是有DMA和串口自动配合完成字符串的发送。这就是简单的异步执行的概念。此例程用到USART类成员函数class USART{public:USART(USART_TypeDef *USARTx,GPIO *tx_pin,GPIO *rx_pin);void begin(uint32_t baud_rate);void printf(const char *fmt,...);此处没有将所有的成员函数列出,只列出了关键方法。详细内容请查看下面的附件。应用实例:#include "ebox.h"void setup(){ ebox_init(); uart1.begin(9600);}int main(void){ setup(); while(1) {uart1.printf("hello World !\r\n");delay_ms(1000); }}好清晰的赶脚啊!uart1对象在哪里创建的呢?USART uart1(USART1,&PA9,&PA10);这是串口1对象的创建。在object.cpp中。声明在eBox.h中。串口详解:我的众筹项目地址:http://z.elecfans.com/30.html 期待大家一起来完善和发展eBox,打造国人自己的库,不仅仅支持STM32,更能支持飞思卡尔MCU、NXP MCU······
2015-11-27 18:51
这段时间eBox在不断的更新内容,先上一个最新的支持!定时器输入捕获模式基础知识:STM32输入捕获模式,主要用于测量输入信号的周期,进而计算波形的频率。正常情况下。输入捕获模式只能测量周期,因为stm32在输入捕获模式设置为检测上升沿或者下降沿。当检测到边沿后,保存定时器的当前值到TIMx->CCR1寄存器。在中断中读取此寄存器就可以得到两个上升沿或者下降沿之间的脉冲数,然后在根据定时器的时钟去计算波形的周期。如果要测量占空比就要在中断中重新设置边沿即可。特点1.支持TIM2,3,4的ch1,2,3,4.共计12个通道2.支持测量周期、频率、高级用法支持测量占空比3.定时器计数器最大值为0xffff,为了突破这个限制, 在本例程中,如果使用了update溢出中断调用overflow_event_process可以将计数器 拓展至2^32。大大提高测量范围,可以实现最高频率(1分频)测量周期低于60s的信号,如果信号长度。 如果使用2分频,可测量周期低于120s的信号,如果信号长度。以此类推。4.get_captur()的精度补偿值 //此处要加一个简单的修正值,此数为测试大致测试结果 //分频系数 | 补偿值 | TIM时钟频率 | 测试频率 //7200分频 | 0| 0.01M |1hz-100hz //720分频| 1| 0.10M |100-1K //72分频| 2| 1.00M |1K //64分频| 3| 1.125M|1K //36分频| 5| 2.00M |1K //32分频| 6| 2.25M |1K //18分频| 11| 4.00M |1K //16分频| 11| 4.50M |1K //9分频 | 18| 8.00M |10K //8分频 | 21| 9.00M |10K-50K //4分频 | 42| 18.0M |10K-50K //2分频 | 84| 36.0M |10K-50K //1分频 | 168 | 72.0M |10K-50K5.关于分频系数和脉冲宽度测量的计算关系,要遵循一个原则:在不溢出的情况下尽量使用低分频系数(高TIM时钟)去检测对象重点: 在采用低分频系数的时候,可以保证测量精度,但是会增大定时器溢出频率,进而增大cpu开销, 在采用高分频系数的时候,测量精度较低,但是会降低定时器溢出频率,进而降低cpu开销, stm32在72M主频下,最高可测160Khz的信号。如果再大,将无法测量。测试例程/*本例程为使用输入捕获模式测量一个PWM信号的周期和频率*/#include "ebox.h"IN_CAPTURE ic(&PA0);//创建一个输入捕获的对象PWM pwm1(&PB8);//创建一个PWM输出对象uint32_t value1;uint32_t value2;void mesure_frq()//输入捕获中断事件{ ic.set_count(0); value1 = ic.get_capture() + 170;//此处是一个校正值,查表可得。}void update_event(){ ic.overflow_event_process();}uint16_t p;void setup(){ebox_init();uart1.begin(115200); p = 1; ic.begin(p);//初始化输入捕获参数,p分频 ic.attch_ic_interrupt(mesure_frq);//绑定捕获中断事件函数 ic.attch_update_interrupt(update_event); pwm1.begin(1000,900); pwm1.set_oc_polarity(1);}int main(void){setup();while(1) {if(value1){uart1.printf("overtimes = %d\r\n",ic.get_overflow_state());uart1.printf("value1 = %d\r\n",value1);//输出PWM周期uart1.printf("frq = %0.0f\r\n",(72000000.0/p)/(value1));//输出PWM频率value1 = 0;}}应用场合 1.红外遥控接收解码。2.DS18B20温度解读。DHT11温湿度模块读取温度3.测电机转速。等等,只要是需要测频率、周期、占空比相关的,都可以用此代码来实现!上传一个工程:我的众筹项目地址:http://z.elecfans.com/30.html 期待大家一起来完善和发展eBox,打造国人自己的库,不仅仅支持STM32,更能支持飞思卡尔MCU、NXP MCU······
2016-01-09 15:35
目录是什么用途结构示意图工作原理磁学原理电子学原理机械原理是什么音圈电机(Voice Cil Actuato r) 是一种特殊形式的直接驱动电机,具有结构简单、体积小、高速、高加速、响应快等特性。音
2021-08-31 07:53
音圈电机(Actuator,而不是Motor) 是一种直接驱动电机(直接驱动是将电机动子直接连接到负载上,实现对负载的直接驱动),是机电控制系统中的执行机构,其具有结构简单、体积小、高速、高加速
2021-08-31 08:14
及践行者。电子发烧友通过openDACS社区开发者计划,凝聚教育资源,搭建学习、技术交流平台,打造openDACS生态圈,助推openDACS生态和人才的发展。华秋电子一站式服务华秋电子通过媒体社区
2022-07-08 13:50
` 本帖最后由 tmmor 于 2018-3-12 15:20 编辑 音圈电机是一种将电能转化为机械能的装置,并实现直线型及有限摆角的运动。它利用来自永恒磁场或通电线圈导体产生的磁场中磁极
2018-03-12 15:08