经过一段时间的51单片机学习,参考前辈的资料利用废旧光驱制作了一个激光雕刻机、激光切割机,下面就是我的制作过程,与大家分享一下成功新的,再次感谢前辈的资料,让小弟少走了六十公里弯路。

废话不多说直接上实物图:

首先拆解废旧光驱


取出步进电机架子↓

把光驱外壳折叠成这个样子↓


把丝杆与步进电机这样固定住,小铁棒就是激光的位置。↓


这个铁棒是为了让它垂直的↓


这个古代软盘就是工作台,哈哈全是废物利用↓

开始焊接杜邦线↓

基本成型

成型

上位机软件截图

简单接线图

元器件清单

台式机光驱 x2
l298n电机驱动模块 x2
51最小系统 x1
usb-ttl模块 x1
uln2003模块 x1
250mw激光模组 x1
导线若干

参考C程序

/*z地址定义
50 1=x+,2=x-,3=y+,4=y-
51 前进后退步数高
52 前进后退步数低
53
54/55 字宽
56
57 弱光开关
58/59 激光强度
60 x轴速度
61 y轴速度
62 开始打印0,57
63 暂停
64 停止标志
65
66 左右标记
100开始时灰度图数据
*/

#include <reg52.h>
#define uint unsigned int
#define uchar unsigned char
#define N z[60] //X速度
#define M z[61] //Y速度
sbit a=P1^3;//步进电机接线定义 移动激光头
sbit a_=P1^2;
sbit b=P1^1;
sbit b_=P1^0;
sbit xa=P1^4;
sbit xa_=P1^5;
sbit xb=P1^6;
sbit xb_=P1^7;
/*sbit a=P1^4;//步进电机接线定义 移动底板
sbit a_=P1^5;
sbit b=P1^6;
sbit b_=P1^7;
sbit xa=P1^3;
sbit xa_=P1^2;
sbit xb=P1^1;
sbit xb_=P1^0; */
sbit jg=P2^0;
sbit led=P2^1;//指示灯
uchar xdata z[500]={0};//缓存
uchar buff[3];//串口缓存
uchar x1,x0,y1,y0,cont2=0;
uchar xfb=4,yfb=4;//走步标志位

unsigned char HighRH = 0; //高电平重载值的高字节
unsigned char HighRL = 0; //高电平重载值的低字节
unsigned char LowRH = 0; //低电平重载值的高字节
unsigned char LowRL = 0; //低电平重载值的低字节

void delayms(uint xms)
{
uint i,j;
for(i=xms;i>0;i–) //i=xms即延时约xms毫秒
for(j=110;j>0;j–);
}

/* 配置并启动PWM,fr-频率,dc-占空比 */
void ConfigPWM(unsigned int fr, unsigned char dc)
{
unsigned int high, low;
unsigned long tmp;

tmp = (11059200/12) / fr; //计算一个周期所需的计数值
high = (tmpdc) / 100; //计算高电平所需的计数值
low = tmp - high; //计算低电平所需的计数值
high = 65536 - high + 12; //计算高电平的重载值并补偿中断延时
low = 65536 - low + 12; //计算低电平的重载值并补偿中断延时
HighRH = (unsigned char)(high>>8); //高电平重载值拆分为高低字节
HighRL = (unsigned char)high;
LowRH = (unsigned char)(low>>8); //低电平重载值拆分为高低字节
LowRL = (unsigned char)low;
TMOD &= 0xF0; //清零T0的控制位
TMOD |= 0x01; //配置T0为模式1
TH0 = HighRH; //加载T0重载值
TL0 = HighRL;
ET0 = 1; //使能T0中断
TR0 = 1; //启动T0
jg = 1; //输出低电平,关闭激光
}
/
关闭PWM /
void ClosePWM()
{
TR0 = 0; //停止定时器0
ET0 = 0; //禁止定时器0中断
jg = 1; //输出低电平,关闭激光
}
/
T0中断服务函数,产生PWM输出 */
void InterruptTimer0() interrupt 1
{
if (jg == 1) //当前输出为低电平时,装载高电平值并输出高电平
{
TH0 = LowRH;
TL0 = LowRL;
jg = 0;
}
else //当前输出为高电平时,装载低电平值并输出低电平
{
TH0 = HighRH;
TL0 = HighRL;
jg = 1;
}
}

void xfor(uint i) //x轴前进函数,前进多少步
{
while(1)
{
if(xfb4)
{
xa=xb=1;
xb_=xa_=0;
xfb=1;
i–;
delayms(N);
if(i0){xa=xb=0; break;}
}
if(xfb1)
{
xb=xa_=1;
xa=xb_=0;
xfb=2;
i–;
delayms(N);
if(i0){xa_=xb=0; break;}
}
if(xfb2)
{
xa_=xb_=1;
xb=xa=0;
xfb=3; //走步标志位
i–;
delayms(N);
if(i0){xa_=xb_=0; break;}
}
if(xfb3)
{
xa_=xb=0;
xb_=xa=1;
xfb=4;
i–;
delayms(N);
if(i0){xa=xb_=0; break;}
}

            }

}

void xbac(uint i) //xxx后退函数
{
while(1)
{
if(xfb1)
{
xa_=xb=0;
xb_=xa=1;
xfb=4;
i–; //走步标志位
delayms(N);
if(i0){xa=xb_=0; break;}
}
if(xfb4)
{
xa_=xb_=1;
xb=xa=0;
xfb=3;
i–;
delayms(N);
if(i0){xa_=xb_=0; break;}
}
if(xfb3)
{
xb=xa_=1;
xa=xb_=0;
xfb=2; //走步标志位
i–;
delayms(N);
if(i0){xa_=xb=0; break;}
}
if(xfb2)
{
xa=xb=1;
xb_=xa_=0;
xfb=1;
i–;
delayms(N);
if(i0){xa=xb=0; break;}
}
}
}

void yfor(uint i) //y轴前进函数
{
while(1)
{
switch(yfb)
{
case 4:{a=b=1; b_=a_=0; yfb=1; i–; delayms(M); if(i0){a=b=0;break;}}
case 1:{b=a_=1; a=b_=0; yfb=2; i–; delayms(M); if(i0){a_=b=0;break;}}
case 2:{a_=b_=1; b=a=0; yfb=3; i–; delayms(M); if(i0){a_=b_=0;break;}}
case 3:{b_=a=1; a_=b=0; yfb=4; i–; delayms(M); if(i0){a=b_=0;break;}}
}
if(i==0) break;
}
}

void ybac(uint i) //yy后退函数
{
while(1)
{
switch(yfb)
{
case 1:{a=b_=1; b=a_=0; yfb=4; i–; delayms(M); if(i0){a=b_=0;break;}}
case 4:{b_=a_=1; a=b=0; yfb=3; i–; delayms(M); if(i0){a_=b_=0;break;}}
case 3:{a_=b=1; b_=a=0; yfb=2; i–; delayms(M); if(i0){a_=b=0;break;}}
case 2:{b=a=1; a_=b_=0; yfb=1; i–; delayms(M); if(i0){a=b=0;break;}}
}
if(i==0) break;
}
}

void dazi(uint zik)//打印函数 打印函数已更改
{
uint x;
jg=0;

for(x=0;x<zik;x++)//执行zik个循环,x轴右移zik步
{
while(z[63]); //暂停等待
if(z[64]==1) break;//停止标志 跳出循环
SBUF=255; // 每开始打印一个点,向上位机发送255,上位机进度显示用
jg=0; //开激光
delayms((z[99+x]*(z[58]*256+z[59]))/100);
jg=1; //关闭激光
if(z[66]1)
{
xbac(1);
}
else
{
xfor(1);
}
}
if(z[641]) z[64]=0;
else{yfor(1);} //y轴进一行
z[62]=0; //一行打印完成
SBUF=1; //发送信息,表示打印一行完成

}

/* 串口配置函数,baud-通信波特率 */
void ConfigUART(unsigned int baud)
{
SCON = 0x50; //配置串口为模式1
TMOD &= 0x0F; //清零T1的控制位
TMOD |= 0x20; //配置T1为模式2
TH1 = 256 - (11059200/12/32)/baud; //计算T1重载值
TL1 = TH1; //初值等于重载值
ET1 = 0; //禁止T1中断
ES = 1; //使能串口中断
TR1 = 1; //启动T1
}

void chuanlo() interrupt 4
{
if(RI)
{
buff[cont2]=SBUF;//每次3字节,地址高,地址低,数据,,

cont2++;
if(cont2==3)//每收3个字节,把数据写入地址中
{
z[(buff[0]256)+buff[1]]=buff[2];
cont2=0;
SBUF=0; //
在这里加入这行代码测试一下*************
}
RI=0;

}
if(TI)
{
TI=0;

}
}

鉴于篇幅限制,只能写部分代码

最后,如果有什么意见或者建议欢迎您留言给我,让我们共同学习一起进步,
如果需要 程序完整源代码和 设计文件,请在下方留言或者私信我,看到后会第一时间回复。

谢谢!

项目实战:DIY光驱激光雕刻机-激光切割机 (含制作步骤 实物 图纸 程序 上位机软件 )下载相关推荐

  1. python和台达plc通讯_项目实战:Qt西门子PLC通讯调试和模拟工具(包含PLC上位机通讯,PLC服务器)...

    若该文为原创文章,转载请注明原文出处 本文章博客地址:https://blog.csdn.net/qq21497936/article/details/110071837 各位读者,知识无穷而人力有穷 ...

  2. 项目实战:Qt5/Quick:模仿扣扣登录界面[小程序]

    项目实战:Qt5/Quick:模仿扣扣登录界面[小程序] 目录 编辑环境: 项目: 项目简介: 其他: 1.项目运行效果 2.项目思路分析 3.项目主要源码部分 4.整个项目源码共享 编辑环境: wi ...

  3. 项目总结 -- RFID 读写器上位机软件

    物联网方向的课程项目:RFID 读写器上位机软件,是一个基于MFC的软件,通过与连接的设备(这里是读卡器)与IC卡进行数据的交换,举个例子来说:校园卡,公司的门禁卡等等,这个属于物联网的终端信息交互的 ...

  4. Python上位机软件图形界面实战——PyQt

    转载:https://blog.csdn.net/qq_25939803/article/details/97894219 文章目录 引言 1 环境配置 2 新建一个软件窗口 3 QtDesigner ...

  5. 小型数控雕刻机制作Arduino_基于Arduino DIY的激光雕刻机

    很多人都梦想有一部专属的激光雕刻机,无论是给自己的作品制作实物,还是给木牌刻字.制作印章,都充满了Maker的DIY乐趣,今天出场的是以Arduino为控制核心所DIY的一部小型激光雕刻机. 使用材料 ...

  6. 【Dash搭建可视化网站】项目10:疫情数据可视化大屏制作步骤详解

    疫情数据可视化大屏制作步骤详解 1 项目效果图 2 项目架构 3 文件介绍和功能完善 3.1 assets文件夹介绍 3.2 app.py和index.py文件完善 3.3 header.py文件完善 ...

  7. 【Dash搭建可视化网站】项目12:全球恐怖主义数据大屏制作步骤详解

    全球恐怖主义数据大屏制作步骤详解 1 项目效果图 2 项目架构 3 文件介绍和功能完善 3.1 assets文件夹介绍 3.2 app.py和index.py文件完善 3.3 header.py文件完 ...

  8. python写一个游戏多少代码-Python项目实战之猜数字游戏(含实现代码)

    猜数字游戏,旨在提高初学者对 Python 变量类型以及循环结构的使用. 此游戏的游戏规则如下:程序随机内置一个位于一定范围内的数字作为猜测的结果,由用户猜测此数字.用户每猜测一次,由系统提示猜测结果 ...

  9. 项目实战:51单片机无线音乐门铃设计资料 五首歌曲自由切换 (含实物 图纸 程序 仿真)

    无线门铃又称无线遥控门铃或遥控门铃.无线门铃是利用超再生无线模块来实现无线遥控的,无线门铃不需要布线,安装简单灵活,但是传输距离受传输距离和现场环境影响较大.有线门铃正好与之相反 包含,程序 实物 图 ...

  10. 微信小程序项目实战篇——基于WYY音乐真实接口开发的音乐小程序

    文章目录 一.项目简介 二.项目结构 三.开发工具 四.项目截图 五.项目地址 六.部分代码 七.项目运行 八.特别声明 一.项目简介 此小程序以网易云音乐为原型进行项目构建,使用网易云音乐真实API ...

最新文章

  1. python视频教学视频哪个好-Python入门视频看哪个好?适合初学者的教学视频推荐...
  2. 面试题 03.04. 化栈为队/面试题09. 用两个栈实现队列/232. 用栈实现队列
  3. python画太极八卦图_太极八卦图的正确画法
  4. 华为Mate 40 Pro钢化膜上手:6.6寸大曲率瀑布屏 黑边加速消失
  5. C++实现由二元组建立图的邻接表
  6. Java判断文件是否为图片
  7. 《C语言及程序设计》程序阅读——参数传递方式:传值与传地址
  8. 高分辨率图像剪切——目标检测
  9. (转载)Delphi开发经验谈
  10. PC机装Openwrt19.07做BT下载机的详细配置
  11. 【视频检测】Flow-Guided Feature Aggregation for Video Object Detection
  12. php image函数,操作压缩图片时,png图片压缩后整个图片变黑
  13. 微软流媒体服务器直播,流媒体服务器Flussonic Media Server对直播流进行录制
  14. MP地面站二次开发教程(四)地面站优化及其功能测试
  15. 马化腾说视频号是全公司希望
  16. 图像的拉普拉斯算子之c++实现(qt + 不调包)
  17. 10Redis--主从复制 非常重要、一主二仆、薪火相传、反客为主、哨兵模式
  18. Android--ImageView读取本地路径图片
  19. Java解一元一次方程,一元二次方程,一元三次方程
  20. Java WebMail

热门文章

  1. Oracle的sp,Oracle的X$表系列介绍之-X$KSMSP
  2. 餐饮后厨计算机应用,美萍餐饮管理系统,餐饮管理软件,餐饮软件,酒店收银系统,饭店点菜系统 --- 管理软件 美萍是专家!...
  3. Linux kali2021 密码学PBC库安装
  4. 网络舆情监测系统TOOM
  5. 流程图神器——代码转流程图软件、在线流程图绘制软件
  6. day04 JavaScript高级程序设计 阅读总结
  7. GitHub 标星 15.3k,Java 编程思想最新中文版
  8. 诺基亚5800软件测试初学者,诺基亚5800刷机【教程详解】
  9. ax 2012 随笔
  10. 达梦和oracle数据库对比学习