STC15,AD7705,LCD1602 C程序 程序简单易懂,焊接电路验证过的,可以实现电压测量,精度较高
2022-03-03 00:25:18 96KB STC15,AD7705
1
STC15项目 ,包括软件源码和硬件原理图,软件设计中面向对象的结构设计思想可供学习,很不错
2022-02-21 18:43:26 19.49MB stc15开发 stc15 STC15项目软件 原理图
或许操作系统很流行,因为它的应用很广泛;或许操作系统很难学,因为那只是牛人的玩偶;或许操作系统离我们很远,因为一般的小程序用不到;或许操作系统很大,小小的单片机根本胜任不了。最后单片机初学者的定论是:操作系统是“高富帅”,与我们这些“矮矬穷”没关系。那笔者告诉你,其实这个“高富帅”也只是个“纸老虎”,只要你肯坚持、刀足够锋利,捅破它不是一件难事,狭路相逢勇者胜。
2022-02-18 22:11:59 1.64MB 嵌入式 STC15单片机 RTX51 Tiny
1
STC15系列单片机的库函数和例程,希望能帮到大家!
2022-02-17 09:48:17 2.25MB 库函数
1
功能: 1、dth22探测室内温度和湿度 2、ds18b20拉线到户外探测室外温度(实测3米的线依旧好用) 3、室内温湿度和户外温度通过lcd1602实时显示 4、接受红外遥控,通过tts模块语音播报相关数据 5、湿度超标,点亮led灯以作警示。 注意: 本例在stc15,11.0592工作频率下测试通过 tts模块可以淘宝购买,接收串口数据直接播报的那种 如果你有小爱音箱红外遥控版,通过设置,即可通过问小爱,然后由本例的tts模块播报,很酷。 这个小东西在冬天特别实用,可以参考早上户外的真实温度穿衣。湿度过低,也会用led提醒你开加湿器。
2022-02-09 14:05:26 180KB stc15 dth22 HX1838 小爱同学红外
STC15系列数据手册,开发过程中经常用到,可以查看相应技术要点和相关寄存器配置,并配有相关实例介绍各个部分的功能
2022-01-25 20:51:24 25.78MB STC15 单片机 收据手册
1
工程1: 使用STC15单片机硬件SPI读取SD卡对应地址的内容。无文件系统,可使用SD卡作为外部数据大容量存储设备。 工程2: 使用STC15单片机硬件SPI挂在fatfs文件系统,读取txt的内容。可方便得用与文件存储与读取。
2022-01-20 14:47:29 311KB STC15 SD卡 fatfs 文件系统
1
设计基本要求: (1)制作一个小型的传输带控制系统,传输带上没有物件的时候停止传输带运行,传输带有物件后,根据物件的颜色可以使得传输带传输的速度不同,至少有两种明显的速度区分,传输带模型如下图1所示,传输带提供了传输带模型和直流电机,其他控制电路自制。 (2)系统具有显示屏,可以统计各组不同颜色物件当前已传输的数量。
2022-01-11 09:05:11 861KB 单片机 51单片机 stc15
1
/*---------------------------------------------------------------------*/ /* --- STC MCU Limited ------------------------------------------------*/ /* --- 使用主芯片对从芯片(限STC15系列)进行ISP下载举例 -----------------*/ /* --- Mobile: (86)13922805190 ----------------------------------------*/ /* --- Fax: 86-755-82905966 -------------------------------------------*/ /* --- Tel: 86-755-82948412 -------------------------------------------*/ /* --- Web: www.STCMCU.com --------------------------------------------*/ /* 如果要在程序中使用此代码,请在程序中注明使用了宏晶科技的资料及程序 */ /* 如果要在文章中应用此代码,请在文章中注明使用了宏晶科技的资料及程序 */ /*---------------------------------------------------------------------*/ //本示例在Keil开发环境下请选择Intel的8058芯片型号进行编译 //假定测试芯片的工作频率为11.0592MHz //注意:使用本代码对STC15系列的单片机进行下载时,必须要执行了Download代码之后, //才能给目标芯片上电,否则目标芯片将无法正确下载 #include "reg51.h" typedef bit BOOL; typedef unsigned char BYTE; typedef unsigned short WORD; typedef unsigned long DWORD; //宏、常量定义 #define FALSE 0 #define TRUE 1 #define LOBYTE(w) ((BYTE)(WORD)(w)) #define HIBYTE(w) ((BYTE)((WORD)(w) >> 8)) #define MINBAUD 2400L #define MAXBAUD 115200L #define FOSC 11059200L //主控芯片工作频率 #define BR(n) (65536 - FOSC/4/(n)) //主控芯片串口波特率计算公式 #define T1MS (65536 - FOSC/1000) //主控芯片1ms定时初值 #define FUSER 24000000L //15系列目标芯片工作频率 #define RL(n) (65536 - FUSER/4/(n)) //15系列目标芯片串口波特率计算公式 //SFR定义 sfr AUXR = 0x8e; //变量定义 BOOL f1ms; //1ms标志位 BOOL UartBusy; //串口发送忙标志位 BOOL UartReceived; //串口数据接收完成标志位 BYTE UartRecvStep; //串口数据接收控制 BYTE TimeOut; //串口通讯超时计数器 BYTE xdata TxBuffer[256]; //串口数据发送缓冲区 BYTE xdata RxBuffer[256]; //串口数据接收缓冲区 char code DEMO[256]; //演示代码数据 //函数声明 void Initial(void); void DelayXms(WORD x); BYTE UartSend(BYTE dat); void CommInit(void); void CommSend(BYTE size); BOOL Download(BYTE *pdat, long size); //主函数入口 void main(void) { while (1) { Initial(); if (Download(DEMO, 0x0100)) { //下载成功 P3 = 0xff; DelayXms(500); P3 = 0x00; DelayXms(500); P3 = 0xff; DelayXms(500); P3 = 0x00; DelayXms(500); P3 = 0xff; DelayXms(500); P3 = 0x00; DelayXms(500); P3 = 0xff; } else { //下载失败 P3 = 0xff; DelayXms(500); P3 = 0xf3; DelayXms(500); P3 = 0xff; DelayXms(500); P3 = 0xf3; DelayXms(500); P3 = 0xff; DelayXms(500); P3 = 0xf3; DelayXms(500); P3 = 0xff; } } } //1ms定时器中断服务程序 void tm0(void) interrupt 1 using 1 { static BYTE Counter100; f1ms = TRUE; if (Counter100-- == 0) { Counter100 = 100; if (TimeOut) TimeOut--; } } //串口中断服务程序 void uart(void) interrupt 4 using 1 { static WORD RecvSum; static BYTE RecvIndex; static BYTE RecvCount; BYTE dat; if (TI) { TI = 0; UartBusy = FALSE; } if (RI) { RI = 0; dat = SBUF; switch (UartRecvStep) { case 1: if (dat != 0xb9) goto L_CheckFirst; UartRecvStep++; break; case 2: if (dat != 0x68) goto L_CheckFirst; UartRecvStep++; break; case 3: if (dat != 0x00) goto L_CheckFirst; UartRecvStep++; break; case 4: RecvSum = 0x68 + dat; RecvCount = dat - 6; RecvIndex = 0; UartRecvStep++; break; case 5: RecvSum += dat; RxBuffer[RecvIndex++] = dat; if (RecvIndex == RecvCount) UartRecvStep++; break; case 6: if (dat != HIBYTE(RecvSum)) goto L_CheckFirst; UartRecvStep++; break; case 7: if (dat != LOBYTE(RecvSum)) goto L_CheckFirst; UartRecvStep++; break; case 8: if (dat != 0x16) goto L_CheckFirst; UartReceived = TRUE; UartRecvStep++; break; L_CheckFirst: case 0: default: CommInit(); UartRecvStep = (dat == 0x46 ? 1 : 0); break; } } } //系统初始化 void Initial(void) { UartBusy = FALSE; SCON = 0xd0; //串口数据模式必须为8位数据+1位偶检验 AUXR = 0xc0; TMOD = 0x00; TH0 = HIBYTE(T1MS); TL0 = LOBYTE(T1MS); TR0 = 1; TH1 = HIBYTE(BR(MINBAUD)); TL1 = LOBYTE(BR(MINBAUD)); TR1 = 1; ET0 = 1; ES = 1; EA = 1; } //Xms延时程序 void DelayXms(WORD x) { do { f1ms = FALSE; while (!f1ms); } while (x--); } //串口数据发送程序 BYTE UartSend(BYTE dat) { while (UartBusy); UartBusy = TRUE; ACC = dat; TB8 = P; SBUF = ACC; return dat; } //串口通讯初始化 void CommInit(void) { UartRecvStep = 0; TimeOut = 20; UartReceived = FALSE; } //发送串口通讯数据包 void CommSend(BYTE size) { WORD sum; BYTE i; UartSend(0x46); UartSend(0xb9); UartSend(0x6a); UartSend(0x00); sum = size + 6 + 0x6a; UartSend(size + 6); for (i=0; i
1
【STC15系列】SYK-0806-A2S1- 05-定时器控制的流水灯
2022-01-05 16:03:05 65KB 【STC15系列】 SYK-0806-A2S1
1