Marlin固件之—:基础入门与测试

article/2025/9/13 3:51:45

一、Marlin的简单介绍

Marlin固件是一个3D打印的开源固件,3D打印固件有许多,Marlin最为健全和强大,当然相对也会复杂一些。使用Gcode控制爱,Gcode是数控机床等工控控制使用范围较广的一种指令协议。在这里介绍一些Marlin的入门经验。

Marlin固件的下载地址:https://github.com/MarlinFirmware/Marlin

Marlin配置与软件详解:

http://wenku.baidu.com/link?url=6SpLLAaNvEk5KCjpkvC6ZnOiCB-9_tOqhoW8D8TrmthRdhWnHGuYjjgUINbMqsHo5XLP06YBrOU9NB9-W9vezNcNFHFny-JUxk2wlEkKfBC&qq-pf-to=pcqq.c2c

http://www.slideshare.net/roboard/3d-printer-marlin

Gcode解读:http://www.3ddayin.net/3ddayinjiceping/1141_2.html

RepRap网址:http://reprap.org/wiki/RepRap_Options#Slicing_Software


二、Marlin的配置

我使用的是MKS BASE开发板,arduino2560,简单罗列一下我认为比较重要的固件配置:

Marlin固件的基本配置:Configuration.h

#define SERIAL_PORT 0                                                          //串口号

#define BAUDRATE 250000                                                    //波特率

#define MOTHERBOARD BOARD_RAMPS_13_EFB           //板级型号

#define CUSTOM_MENDEL_NAME "UARMBOT"              //液晶屏显示内容

#define EXTRUDERS 1                                                             //挤出头个数

#define TEMP_SENSOR_0 1                                                   //挤出头1,温度传感器型号

#define TEMP_SENSOR_1 0                                                   //没有则为0

#define TEMP_SENSOR_2 0

#define TEMP_SENSOR_BED 0

 

#define HEATER_0_MINTEMP 5                                   //喷嘴1的最低温度

#define HEATER_1_MINTEMP 5

#define HEATER_2_MINTEMP 5

#define BED_MINTEMP 5

#define HEATER_0_MAXTEMP 50                               //喷嘴1的最高温度

#define HEATER_1_MAXTEMP 50

#define HEATER_2_MAXTEMP 50

#define BED_MAXTEMP 50

#define DISABLE_X false                                                //失能某一个轴

#define DISABLE_Y false

#define DISABLE_Z false

#define DISABLE_E false 

#define DISABLE_INACTIVE_EXTRUDERtrue 

#define INVERT_X_DIR false                                        //转动方向

#define INVERT_Y_DIR false   

#define INVERT_Z_DIR false  

#define INVERT_E0_DIR false  

#define INVERT_E1_DIR false   

#define INVERT_E2_DIR false  

#define X_HOME_DIR  1  //home的方向和起始位置:1=MAX, -1=MIN

#define Y_HOME_DIR  1  //但是MANUAL_HOME_POSITIONS定义之后起始位置就可以自己设定

#define Z_HOME_DIR  1

#define X_MAX_POS 500                                               //xyz的最大最小值

#define X_MIN_POS -500

#define Y_MAX_POS 500

#define Y_MIN_POS -500

#define Z_MAX_POS 500

#define Z_MIN_POS -500

#define MANUAL_X_HOME_POS 0                             //home的起始坐标,需要宏定义

MANUAL_HOME_POSITIONS

#define MANUAL_Y_HOME_POS 0

#define MANUAL_Z_HOME_POS 0

 

#define NUM_AXIS  4                                                      //轴的数量和回home时的速度

#define HOMING_FEEDRATE {5*600, 5*600,5*600, 0}  

 

//单位1mm距离所对应的脉冲数,移动1mm的step数

#define DEFAULT_AXIS_STEPS_PER_UNIT  {50.0,50.0,50.0,192.59924}  

#define DEFAULT_MAX_FEEDRATE             {5000, 5000, 5000,5000}   //最大速度(mm/sec)

#define DEFAULT_MAX_ACCELERATION     {9000,9000,9000,9000}    //最大加速度

#define DEFAULT_ACCELERATION         1000                                         //默认的打印加速度

#define DEFAULT_RETRACT_ACCELERATION 1000                                //默认的收缩加速度

//单次最大加速度的速度,小则打的细腻但是慢,大则粗糙但快

#define DEFAULT_XYJERK               200.0    // (mm/sec)

#define DEFAULT_ZJERK                200.0    // (mm/sec)

#define DEFAULT_EJERK                200.0    // (mm/sec)


三、Marlin特殊机械结构的坐标计算

  因为我调试的机械是一个三轴的机械臂,我的calculate_delta也是自己计算的

voidcalculate_delta(float cartesian[3])

{

    double _stretch =sqrt(sq(cartesian[Y_AXIS]+lenght_oright_to_home+lenght_center_to_origin)+sq(cartesian[X_AXIS]))-lenght_center_to_origin;        

    double _height = cartesian[Z_AXIS]+height_oright_to_home;            

    double xx =_stretch*_stretch+_height*_height;

    double xxx=ARM_B2-ARM_A2+xx;

    double angleB=acos((_stretch*xxx+_height*sqrt(4.0*ARM_B2*xx-xxx*xxx))/(xx*2.0*ARM_B))*RAD_TO_DEG;

    xxx=ARM_A2-ARM_B2+xx;

    double angleA=acos((_stretch*xxx-_height*sqrt(4.0*ARM_A2*xx-xxx*xxx))/(xx*2.0*ARM_A))*RAD_TO_DEG;

    delta[X_AXIS]=atan(cartesian[X_AXIS]/(cartesian[Y_AXIS]+lenght_oright_to_home+lenght_center_to_origin))*RAD_TO_DEG;// 21是圆心到原点的Y轴偏移

    delta[Y_AXIS] =(angleA - angle_lower_arm);                            delta[Z_AXIS]=(angleB - angle_upper_arm) ;                  

    //将角度转换为脉冲数

    delta[X_AXIS] *= pulse_UNIT_angle;

    delta[Y_AXIS] *= pulse_UNIT_angle;

    delta[Z_AXIS] *= pulse_UNIT_angle;

}

 

四、测试如下:

1、首先在网上下载一些简笔图画或者自己在电脑的画画板写上字,保证背景纯白色(图像处理的简单一些)

        

2、使用b2g软件生成Gcode代码,然后使用文本打开Gcode,手动调整一下Gcode的写字画画的高度和速度。

3、使用pronterface软件与机械臂相连并发送生成的Gcode。

4、效果图:图上的文字和图片都是机械臂画出来的

        



http://chatgpt.dhexx.cn/article/8aOC8nf1.shtml

相关文章

Marlin固件介绍

目录 什么是Marlin? 主要特点 Marlin如何工作 打印东西 建模 …

marlin2.0.x 固件相关配置文档说明

主要目的 了解对应参数的作用,以优化3D打印机的打印效果 具体分析 配置文件有两个 Configuration.h 包含硬件核心、语言和控制器的设置,以及最常见的功能和组件的设置,主要配置的地方。 Configuration_adv.h 提供更详细的自定义选项&…

杨辉三角形--2021蓝桥杯Java组

杨辉三角形–2021蓝桥杯Java组 题目描述 下面的图形是著名的杨辉三角形: 如果我们按从上到下、从左到右的顺序把所有数排成一列,可以得到如下数列:1,1,1,1,2,1,1,3,3,1,1,4,6,4,1,⋯ 给定一个正整数 N,请你输出数列中第一次出现…

JAVA杨辉三角形

杨辉三角形 杨辉三角形(java)首先让我们来实现要求一再来看看要求二对于要求三最后一步给三角形前面加上空格 杨辉三角形(java) 首先让我们来看看杨辉三角形的结构: 要求一:有一个数第二层有两个数要求二:每一层第一个跟最后一个数字都是一**要求三:除了数字一以外其他数字等于…

汉罗塔问题和杨辉三角(java实现)

汉罗塔问题和杨辉三角问题 汉罗塔思路分析:代码: 杨辉三角思路分析代码 汉罗塔 相传在古印度圣庙中,有一种被称为汉诺塔(Hanoi)的游戏。该游戏是在一块铜板装置上,有三根杆(编号A、B、C),在A杆自下而上、由大到小按顺…

杨辉三角形 (蓝桥杯) JAVA

目录 题目描述:暴力破解(四成):二分法破解(满分): 题目描述: 下面的图形是著名的杨辉三角形: 如果我们按从上到下、从左到右的顺序把所有数排成一列,可以得到…

【leetcode刷题】34.杨辉三角——Java版

⭐欢迎订阅《leetcode》专栏,每日一题,每天进步⭐ 帕斯卡可能是马可波罗的亲戚,马可波罗回到欧洲后,把杨辉三角告诉了帕斯卡,最后帕斯卡漂亮了抄袭了杨辉三角 ——leetcode此题热评 前言 哈喽,大家好&…

使用Java代码实现杨辉三角

什么是杨辉三角 杨辉三角是中国古代数学的杰出研究成果之一,它把二项式系数图形化,把组合数内在的一些代数性质直观地从图形中体现出来,是一种离散型的数与形的结合 一般我们见到的图形是这样的 很容易可以看出第三行的2,是上方的…

java 实现打印杨辉三角

package com.shan;import java.util.Scanner;public class YFTriangle {public static void main(String[] args) {printYFTriangle();}/*** 1 要理解下面的实现,首先要明白int数组中元素默认值为 0* 2 然后每一次迭代打印新的一行的元素的时候:* 新的特…

【Java——打印杨辉三角】

文章目录 (一)编程实现(二)讲解知识点1、指定二维数组行数与列数2、指定二维数组行数,不指定列数3、直接使用嵌套大括号“{}”静态初始化二维数组 (三)拓展练习任务1、求二维数组最值及位置任务…

两种方法实现杨辉三角(java实现)

🎉🎉🎉点进来你就是我的人了博主主页:🙈🙈🙈戳一戳,欢迎大佬指点!欢迎志同道合的朋友一起加油喔🦾🦾🦾 目录 目录 打印杨辉三角形 方法一:顺序表实现 (Arra…

一文搞懂 Base64 , 简单!

Base64是一种用64个字符来表示任意二进制数据的方法。 # Base64 编码表(标准) 相信我们都知道ASCII 编码,从A-Z、a-z、0-9和一些其他的特殊字符,这些字符都有唯一的一个数字来表示。 同理Base64也有这样一套编码。 范围是”A-…

base64原理与实现

1. base64 bse64是一种以64个可见字符集对二进制数据进行编码的编码算法。 1.1 应用范围 base64常用于网络数据传输过程的编解码环节。HTTP环境下传递较长的标识信息。例如,在Java Persistence系统Hibernate中,就采用了base64来将一个较长的一个标识符&a…

Base64编码的原理及实现(源码)

Base64编码在邮件中最为常见,呵呵,因为我最近就是在做邮箱报警,SMTP验证就是Base64编码用户名和密码进行验证的,并且附件也是要转换成base64编码的数据,然后再发送的。该编码使用64个明文来编码任意的二进制文件&#…

详述图片base64加密的原理,告诉你什么是“/9j/“

欢迎大家搜索“小猴子的技术笔记”关注我的公众号,有问题可以及时和我交流。 在日常的生活中,我们肯定都经历过类似这样的场景:报名考试上传图片,网站要求的是上传的照片不能大于多少,而且要求是“.jpg”的格式。 于是…

base64编码原理之python应用

base64产生原因? 先看ascii码的图片 scii码的128~255之间的值是不可见字符。而在网络上交换数据时,比如说从A地传到B地,往往要经过多个路由设备,由于不同的设备对字符的处理方式有一些不同,这样那些不可见…

一文搞懂Base64编码原理

Base64是最常见的用于传输8Bit字节码的编码方式之一,它是一种基于64个可打印字符来表示二进制数据的方法。 Base64是什么 Base64编码,是由64个字符组成编码集:26个大写字母AZ,26个小写字母az,10个数字0~9&#xff0c…

Base64编码解码原理

本篇文章主要是从Base64的原理入手,并给出java的Base64实现。方便了解、学习Base64。 base64的简介----摘自于百度百科 一、Base64大致用途 很早之前,电子邮件刚刚问世,那时候消息的传递都是英文,后来中国开通了互联网之后&#…

Java—Base64编码原理

Base64作为java编程中常见的编码方式,经常在各种加密(例如AES、RSA等等)的过程中用来实现加解密中间产物可读性的重要工具,很值得我们去了解一下它的原理。Base64是网络上最常见的用于传输8Bit字节码的编码方式之一,Ba…

一文轻松明白 Base64 编码原理

把图片丢进浏览器,打开sources能看到一长串字符串,这是图片的Base64编码。这一长串编码到底是怎么生成的呢? 我们接下来探索一下base64编码的原理 Base64 名称的由来 Base64编码要求把3个8位的字节(3824)转化为4个6…