hall_filament_width_sensor: Added width logging (#2981)
Signed-off-by: Denis Ignatenko deniss979@gmail.com
This commit is contained in:
parent
4c571ea9ac
commit
b3298d8992
|
@ -2035,6 +2035,9 @@
|
||||||
#measurement_interval: 10
|
#measurement_interval: 10
|
||||||
# The approximate distance (in mm) between sensor readings. The
|
# The approximate distance (in mm) between sensor readings. The
|
||||||
# default is 10mm.
|
# default is 10mm.
|
||||||
|
#logging: False
|
||||||
|
# Out diameter to terminal and klipper.log
|
||||||
|
# can be turn on|of by command
|
||||||
#Virtual filament_switch_sensor support. Create sensor named hall_filament_width_sensor.
|
#Virtual filament_switch_sensor support. Create sensor named hall_filament_width_sensor.
|
||||||
#min_diameter:1.0
|
#min_diameter:1.0
|
||||||
#Minimal diameter for trigger virtual filament_switch_sensor.
|
#Minimal diameter for trigger virtual filament_switch_sensor.
|
||||||
|
|
|
@ -48,6 +48,10 @@ Sensor generates two analog output based on calculated filament width. Sum of ou
|
||||||
# measurement_interval:10
|
# measurement_interval:10
|
||||||
# Sensor readings done with 10 mm intervals by default. If necessary you are free to change this setting
|
# Sensor readings done with 10 mm intervals by default. If necessary you are free to change this setting
|
||||||
|
|
||||||
|
#logging: False
|
||||||
|
# Out diameter to terminal and klipper.log
|
||||||
|
# can be turn on|of by command
|
||||||
|
|
||||||
#Virtual filament_switch_sensor suppurt. Create sensor named hall_filament_width_sensor.
|
#Virtual filament_switch_sensor suppurt. Create sensor named hall_filament_width_sensor.
|
||||||
#
|
#
|
||||||
#min_diameter:1.0
|
#min_diameter:1.0
|
||||||
|
@ -75,6 +79,10 @@ Sensor generates two analog output based on calculated filament width. Sum of ou
|
||||||
|
|
||||||
**QUERY_RAW_FILAMENT_WIDTH** Return the current ADC channel values and RAW sensor value for calibration points
|
**QUERY_RAW_FILAMENT_WIDTH** Return the current ADC channel values and RAW sensor value for calibration points
|
||||||
|
|
||||||
|
**ENABLE_FILAMENT_WIDTH_LOG** - Turn on diameter logging
|
||||||
|
|
||||||
|
**DISABLE_FILAMENT_WIDTH_LOG** - Turn off diameter logging
|
||||||
|
|
||||||
## Menu variables
|
## Menu variables
|
||||||
|
|
||||||
**hall_filament_width_sensor.Diameter** current measured filament width in mm
|
**hall_filament_width_sensor.Diameter** current measured filament width in mm
|
||||||
|
@ -117,3 +125,7 @@ Save raw values in config
|
||||||
## How to enable sensor
|
## How to enable sensor
|
||||||
After power on by default sensor disabled.
|
After power on by default sensor disabled.
|
||||||
Enable sensor in start g-code by command **ENABLE_FILAMENT_WIDTH_SENSOR** or change enable parameter in config
|
Enable sensor in start g-code by command **ENABLE_FILAMENT_WIDTH_SENSOR** or change enable parameter in config
|
||||||
|
|
||||||
|
## Logging
|
||||||
|
After power on by default diameter Logging disabled.
|
||||||
|
Data to log added on every measurement interval (10 mm by default)
|
||||||
|
|
|
@ -31,6 +31,7 @@ class HallFilamentWidthSensor:
|
||||||
self.diameter =self.nominal_filament_dia
|
self.diameter =self.nominal_filament_dia
|
||||||
self.is_active =config.getboolean('enable', False)
|
self.is_active =config.getboolean('enable', False)
|
||||||
self.runout_dia=config.getfloat('min_diameter', 1.0)
|
self.runout_dia=config.getfloat('min_diameter', 1.0)
|
||||||
|
self.is_log =config.getboolean('logging', False)
|
||||||
# Use the current diameter instead of nominal while the first
|
# Use the current diameter instead of nominal while the first
|
||||||
# measurement isn't in place
|
# measurement isn't in place
|
||||||
self.use_current_dia_while_delay = config.getboolean(
|
self.use_current_dia_while_delay = config.getboolean(
|
||||||
|
@ -63,6 +64,11 @@ class HallFilamentWidthSensor:
|
||||||
self.cmd_M405)
|
self.cmd_M405)
|
||||||
self.gcode.register_command('QUERY_RAW_FILAMENT_WIDTH',
|
self.gcode.register_command('QUERY_RAW_FILAMENT_WIDTH',
|
||||||
self.cmd_Get_Raw_Values)
|
self.cmd_Get_Raw_Values)
|
||||||
|
self.gcode.register_command('ENABLE_FILAMENT_WIDTH_LOG',
|
||||||
|
self.cmd_log_enable)
|
||||||
|
self.gcode.register_command('DISABLE_FILAMENT_WIDTH_LOG',
|
||||||
|
self.cmd_log_disable)
|
||||||
|
|
||||||
self.runout_helper = filament_switch_sensor.RunoutHelper(config)
|
self.runout_helper = filament_switch_sensor.RunoutHelper(config)
|
||||||
# Initialization
|
# Initialization
|
||||||
def handle_ready(self):
|
def handle_ready(self):
|
||||||
|
@ -97,6 +103,10 @@ class HallFilamentWidthSensor:
|
||||||
if next_reading_position <= (last_epos + self.measurement_delay):
|
if next_reading_position <= (last_epos + self.measurement_delay):
|
||||||
self.filament_array.append([last_epos + self.measurement_delay,
|
self.filament_array.append([last_epos + self.measurement_delay,
|
||||||
self.diameter])
|
self.diameter])
|
||||||
|
if self.is_log:
|
||||||
|
self.gcode.respond_info("Filament width:%.3f" %
|
||||||
|
( self.diameter ))
|
||||||
|
|
||||||
else:
|
else:
|
||||||
# add first item to array
|
# add first item to array
|
||||||
self.filament_array.append([self.measurement_delay + last_epos,
|
self.filament_array.append([self.measurement_delay + last_epos,
|
||||||
|
@ -190,6 +200,13 @@ class HallFilamentWidthSensor:
|
||||||
'Raw':(self.lastFilamentWidthReading+
|
'Raw':(self.lastFilamentWidthReading+
|
||||||
self.lastFilamentWidthReading2),
|
self.lastFilamentWidthReading2),
|
||||||
'is_active':self.is_active}
|
'is_active':self.is_active}
|
||||||
|
def cmd_log_enable(self, gcmd):
|
||||||
|
self.is_log = True
|
||||||
|
gcmd.respond_info("Filament width logging Turned On")
|
||||||
|
|
||||||
|
def cmd_log_disable(self, gcmd):
|
||||||
|
self.is_log = False
|
||||||
|
gcmd.respond_info("Filament width logging Turned Off")
|
||||||
|
|
||||||
def load_config(config):
|
def load_config(config):
|
||||||
return HallFilamentWidthSensor(config)
|
return HallFilamentWidthSensor(config)
|
||||||
|
|
Loading…
Reference in New Issue