Skip to content
Snippets Groups Projects
Configuration.h 56.4 KiB
Newer Older
  • Learn to ignore specific revisions
  • // When enabled allows the user to send G12 to start the nozzle cleaning
    // process, the G-Code accepts two parameters:
    //   "P" for pattern selection
    //   "S" for defining the number of strokes/repetitions
    //
    // Available list of patterns:
    //   P0: This is the default pattern, this process requires a sponge type
    
    //       material at a fixed bed location. S defines "strokes" i.e.
    //       back-and-forth movements between the starting and end points.
    
    //   P1: This starts a zig-zag pattern between (X0, Y0) and (X1, Y1), "T"
    //       defines the number of zig-zag triangles to be done. "S" defines the
    
    //       number of strokes aka one back-and-forth movement. Zig-zags will
    //       be performed in whichever dimension is smallest. As an example,
    
    //       sending "G12 P1 S1 T3" will execute:
    //
    //          --
    //         |  (X0, Y1) |     /\        /\        /\     | (X1, Y1)
    //         |           |    /  \      /  \      /  \    |
    //       A |           |   /    \    /    \    /    \   |
    //         |           |  /      \  /      \  /      \  |
    //         |  (X0, Y0) | /        \/        \/        \ | (X1, Y0)
    //          --         +--------------------------------+
    //                       |________|_________|_________|
    //                           T1        T2        T3
    
    //   P2: This starts a circular pattern with circle with middle in
    //       NOZZLE_CLEAN_CIRCLE_MIDDLE radius of R and stroke count of S.
    //       Before starting the circle nozzle goes to NOZZLE_CLEAN_START_POINT.
    
    // Caveats: End point Z should use the same value as Start point Z.
    //
    // Attention: This is an EXPERIMENTAL feature, in the future the G-code arguments
    // may change to add new functionality like different wipe patterns.
    //
    
    //#define NOZZLE_CLEAN_FEATURE
    
    #if ENABLED(NOZZLE_CLEAN_FEATURE)
    
      // Default number of pattern repetitions
    
      #define NOZZLE_CLEAN_STROKES  12
    
      // Default number of triangles
      #define NOZZLE_CLEAN_TRIANGLES  3
    
      // Specify positions as { X, Y, Z }
      #define NOZZLE_CLEAN_START_POINT { 30, 30, (Z_MIN_POS + 1)}
      #define NOZZLE_CLEAN_END_POINT   {100, 60, (Z_MIN_POS + 1)}
    
      // Circular pattern radius
      #define NOZZLE_CLEAN_CIRCLE_RADIUS 6.5
      // Circular pattern circle fragments number
      #define NOZZLE_CLEAN_CIRCLE_FN 10
      // Middle point of circle
      #define NOZZLE_CLEAN_CIRCLE_MIDDLE NOZZLE_CLEAN_START_POINT
    
    
      // Moves the nozzle to the initial position
      #define NOZZLE_CLEAN_GOBACK
    
    // Enable this option to automatically start and stop the
    
    // print job timer when M104/M109/M190 commands are received.
    // M104 (extruder without wait) - high temp = none, low temp = stop timer
    // M109 (extruder with wait) - high temp = start timer, low temp = stop timer
    // M190 (bed with wait) - high temp = start timer, low temp = none
    
    // In all cases the timer can be started and stopped using
    // the following commands:
    
    //
    // - M75  - Start the print job timer
    // - M76  - Pause the print job timer
    // - M77  - Stop the print job timer
    
    #define PRINTJOB_TIMER_AUTOSTART
    
    
    //
    // Print Counter
    //
    // When enabled Marlin will keep track of some print statistical data such as:
    //  - Total print jobs
    
    //  - Total successful print jobs
    
    //  - Total failed print jobs
    //  - Total time printing
    //
    // This information can be viewed by the M78 command.
    //#define PRINTCOUNTER
    
    
    //=============================================================================
    //============================= LCD and SD support ============================
    //=============================================================================
    
    João Brázio's avatar
    João Brázio committed
    // LCD LANGUAGE
    
    //
    // Here you may choose the language used by Marlin on the LCD menus, the following
    // list of languages are available:
    
    //    en, an, bg, ca, cn, cz, de, el, el-gr, es, eu, fi, fr, gl, hr, it,
    
    jes's avatar
    jes committed
    //    kana, kana_utf8, nl, pl, pt, pt_utf8, pt-br, pt-br_utf8, ru, tr, uk, test
    
    jes's avatar
    jes committed
    // :{ 'en':'English', 'an':'Aragonese', 'bg':'Bulgarian', 'ca':'Catalan', 'cn':'Chinese', 'cz':'Czech', 'de':'German', 'el':'Greek', 'el-gr':'Greek (Greece)', 'es':'Spanish', 'eu':'Basque-Euskera', 'fi':'Finnish', 'fr':'French', 'gl':'Galician', 'hr':'Croatian', 'it':'Italian', 'kana':'Japanese', 'kana_utf8':'Japanese (UTF8)', 'nl':'Dutch', 'pl':'Polish', 'pt':'Portuguese', 'pt-br':'Portuguese (Brazilian)', 'pt-br_utf8':'Portuguese (Brazilian UTF8)', 'pt_utf8':'Portuguese (UTF8)', 'ru':'Russian', 'tr':'Turkish', 'uk':'Ukrainian', 'test':'TEST' }
    
    #define LCD_LANGUAGE en
    
    AnHardt's avatar
    AnHardt committed
    
    
    João Brázio's avatar
    João Brázio committed
    //
    // LCD Character Set
    //
    // Note: This option is NOT applicable to Graphical Displays.
    //
    // All character-based LCD's provide ASCII plus one of these
    // language extensions:
    //
    //  - JAPANESE ... the most common
    //  - WESTERN  ... with more accented characters
    //  - CYRILLIC ... for the Russian language
    //
    // To determine the language extension installed on your controller:
    //
    //  - Compile and upload with LCD_LANGUAGE set to 'test'
    //  - Click the controller to view the LCD menu
    //  - The LCD will display Japanese, Western, or Cyrillic text
    //
    // See https://github.com/MarlinFirmware/Marlin/wiki/LCD-Language
    //
    
    // :['JAPANESE', 'WESTERN', 'CYRILLIC']
    
    João Brázio's avatar
    João Brázio committed
    //
    
    #define DISPLAY_CHARSET_HD44780 JAPANESE
    
    //
    // LCD TYPE
    //
    // You may choose ULTRA_LCD if you have character based LCD with 16x2, 16x4, 20x2,
    // 20x4 char/lines or DOGLCD for the full graphics display with 128x64 pixels
    
    João Brázio's avatar
    João Brázio committed
    // (ST7565R family). (This option will be set automatically for certain displays.)
    
    João Brázio's avatar
    João Brázio committed
    // IMPORTANT NOTE: The U8glib library is required for Full Graphic Display!
    //                 https://github.com/olikraus/U8glib_Arduino
    
    //
    //#define ULTRA_LCD   // Character based
    //#define DOGLCD      // Full graphics display
    
    //
    // SD CARD
    //
    
    João Brázio's avatar
    João Brázio committed
    // SD Card support is disabled by default. If your controller has an SD slot,
    // you must uncomment the following option or it won't work.
    
    João Brázio's avatar
    João Brázio committed
    // Uncomment ONE of the following items to use a slower SPI transfer
    // speed. This is usually required if you're getting volume init errors.
    
    //
    //#define SPI_SPEED SPI_HALF_SPEED
    //#define SPI_SPEED SPI_QUARTER_SPEED
    //#define SPI_SPEED SPI_EIGHTH_SPEED
    
    //
    // SD CARD: ENABLE CRC
    //
    // Use CRC checks and retries on the SD communication.
    //
    //#define SD_CHECK_AND_RETRY
    
    João Brázio's avatar
    João Brázio committed
    // This option overrides the default number of encoder pulses needed to
    // produce one step. Should be increased for high-resolution encoders.
    
    //
    //#define ENCODER_PULSES_PER_STEP 1
    
    João Brázio's avatar
    João Brázio committed
    // Use this option to override the number of step signals required to
    // move between next/prev menu items.
    
    //
    //#define ENCODER_STEPS_PER_MENU_ITEM 5
    
    /**
     * Encoder Direction Options
     *
     * Test your encoder's behavior first with both options disabled.
     *
     *  Reversed Value Edit and Menu Nav? Enable REVERSE_ENCODER_DIRECTION.
     *  Reversed Menu Navigation only?    Enable REVERSE_MENU_DIRECTION.
     *  Reversed Value Editing only?      Enable BOTH options.
     */
    
    
    //
    // This option reverses the encoder direction everywhere
    //
    //  Set this option if CLOCKWISE causes values to DECREASE
    //
    //#define REVERSE_ENCODER_DIRECTION
    
    
    João Brázio's avatar
    João Brázio committed
    // This option reverses the encoder direction for navigating LCD menus.
    
    //
    //  If CLOCKWISE normally moves DOWN this makes it go UP.
    //  If CLOCKWISE normally moves UP this makes it go DOWN.
    
    //
    //#define REVERSE_MENU_DIRECTION
    
    //
    // Individual Axis Homing
    //
    // Add individual axis homing items (Home X, Home Y, and Home Z) to the LCD menu.
    //
    //#define INDIVIDUAL_AXIS_HOMING_MENU
    
    
    João Brázio's avatar
    João Brázio committed
    // SPEAKER/BUZZER
    
    João Brázio's avatar
    João Brázio committed
    // If you have a speaker that can produce tones, enable it here.
    // By default Marlin assumes you have a buzzer with a fixed frequency.
    
    João Brázio's avatar
    João Brázio committed
    // The duration and frequency for the UI feedback sound.
    // Set these to 0 to disable audio feedback in the LCD menus.
    
    João Brázio's avatar
    João Brázio committed
    // Note: Test audio output with the G-Code:
    
    //  M300 S<frequency Hz> P<duration ms>
    //
    //#define LCD_FEEDBACK_FREQUENCY_DURATION_MS 100
    //#define LCD_FEEDBACK_FREQUENCY_HZ 1000
    
    //
    // CONTROLLER TYPE: Standard
    //
    
    João Brázio's avatar
    João Brázio committed
    // Marlin supports a wide variety of controllers.
    // Enable one of the following options to specify your controller.
    
    João Brázio's avatar
    João Brázio committed
    // ULTIMAKER Controller.
    
    //
    //#define ULTIMAKERCONTROLLER
    
    João Brázio's avatar
    João Brázio committed
    // ULTIPANEL as seen on Thingiverse.
    
    // Cartesio UI
    // http://mauk.cc/webshop/cartesio-shop/electronics/user-interface
    
    //#define CARTESIO_UI
    
    
    João Brázio's avatar
    João Brázio committed
    // PanelOne from T3P3 (via RAMPS 1.4 AUX2/AUX3)
    // http://reprap.org/wiki/PanelOne
    
    João Brázio's avatar
    João Brázio committed
    // MaKr3d Makr-Panel with graphic controller and SD support.
    // http://reprap.org/wiki/MaKr3d_MaKrPanel
    
    //
    // ReprapWorld Graphical LCD
    // https://reprapworld.com/?products_details&products_id/1218
    //
    //#define REPRAPWORLD_GRAPHICAL_LCD
    
    
    João Brázio's avatar
    João Brázio committed
    // Activate one of these if you have a Panucatt Devices
    // Viki 2.0 or mini Viki with Graphic LCD
    // http://panucatt.com
    
    Natealus's avatar
    Natealus committed
    //#define VIKI2
    //#define miniVIKI
    
    
    João Brázio's avatar
    João Brázio committed
    // Adafruit ST7565 Full Graphic Controller.
    
    // https://github.com/eboston/Adafruit-ST7565-Full-Graphic-Controller/
    //
    
    Ed Boston's avatar
    Ed Boston committed
    //#define ELB_FULL_GRAPHIC_CONTROLLER
    
    João Brázio's avatar
    João Brázio committed
    // RepRapDiscount Smart Controller.
    
    // http://reprap.org/wiki/RepRapDiscount_Smart_Controller
    
    João Brázio's avatar
    João Brázio committed
    // Note: Usually sold with a white PCB.
    
    //#define REPRAP_DISCOUNT_SMART_CONTROLLER
    
    João Brázio's avatar
    João Brázio committed
    // GADGETS3D G3D LCD/SD Controller
    
    Nicolas Rossi's avatar
    Nicolas Rossi committed
    // http://reprap.org/wiki/RAMPS_1.3/1.4_GADGETS3D_Shield_with_Panel
    
    João Brázio's avatar
    João Brázio committed
    // Note: Usually sold with a blue PCB.
    
    daid303's avatar
    daid303 committed
    //#define G3D_PANEL
    
    João Brázio's avatar
    João Brázio committed
    // RepRapDiscount FULL GRAPHIC Smart Controller
    
    // http://reprap.org/wiki/RepRapDiscount_Full_Graphic_Smart_Controller
    //
    
    //#define REPRAP_DISCOUNT_FULL_GRAPHIC_SMART_CONTROLLER
    
    João Brázio's avatar
    João Brázio committed
    // MakerLab Mini Panel with graphic
    
    // controller and SD support - http://reprap.org/wiki/Mini_panel
    
    João Brázio's avatar
    João Brázio committed
    // RepRapWorld REPRAPWORLD_KEYPAD v1.1
    
    // http://reprapworld.com/?products_details&products_id=202&cPath=1591_1626
    
    //
    // REPRAPWORLD_KEYPAD_MOVE_STEP sets how much should the robot move when a key
    // is pressed, a value of 10.0 means 10mm per click.
    //
    
    //#define REPRAPWORLD_KEYPAD
    
    //#define REPRAPWORLD_KEYPAD_MOVE_STEP 1.0
    
    //
    // RigidBot Panel V1.0
    // http://www.inventapart.com/
    //
    //#define RIGIDBOT_PANEL
    
    //
    // BQ LCD Smart Controller shipped by
    // default with the BQ Hephestos 2 and Witbox 2.
    //
    //#define BQ_LCD_SMART_CONTROLLER
    
    
    //
    // CONTROLLER TYPE: I2C
    //
    // Note: These controllers require the installation of Arduino's LiquidCrystal_I2C
    // library. For more info: https://github.com/kiyoshigawa/LiquidCrystal_I2C
    //
    
    João Brázio's avatar
    João Brázio committed
    // Elefu RA Board Control Panel
    
    // http://www.elefu.com/index.php?route=product/product&product_id=53
    
    
    //
    // Sainsmart YW Robot (LCM1602) LCD Display
    //
    
    //#define LCD_I2C_SAINSMART_YWROBOT
    
    // Generic LCM1602 LCD adapter
    
    João Brázio's avatar
    João Brázio committed
    // PANELOLU2 LCD with status LEDs,
    
    // separate encoder and click inputs.
    //
    // Note: This controller requires Arduino's LiquidTWI2 library v1.2.3 or later.
    // For more info: https://github.com/lincomatic/LiquidTWI2
    //
    // Note: The PANELOLU2 encoder click input can either be directly connected to
    // a pin (if BTN_ENC defined to != -1) or read through I2C (when BTN_ENC == -1).
    //
    
    //#define LCD_I2C_PANELOLU2
    
    João Brázio's avatar
    João Brázio committed
    // Panucatt VIKI LCD with status LEDs,
    
    // integrated click & L/R/U/D buttons, separate encoder inputs.
    //
    
    //#define LCD_I2C_VIKI
    
    João Brázio's avatar
    João Brázio committed
    // SSD1306 OLED full graphics generic display
    
    //#define U8GLIB_SSD1306
    
    // SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
    
    //#define SAV_3DGLCD
    #if ENABLED(SAV_3DGLCD)
      //#define U8GLIB_SSD1306
      #define U8GLIB_SH1106
    #endif
    
    
    //
    // CONTROLLER TYPE: Shift register panels
    //
    // 2 wire Non-latching LCD SR from https://goo.gl/aJJ4sH
    
    // LCD configuration: http://reprap.org/wiki/SAV_3D_LCD
    
    //#define SAV_3DLCD
    
    //=============================================================================
    //=============================== Extra Features ==============================
    //=============================================================================
    
    
    // Increase the FAN PWM frequency. Removes the PWM noise but increases heating in the FET/Arduino
    
    // Use software PWM to drive the fan, as for the heaters. This uses a very low frequency
    
    // which is not as annoying as with the hardware PWM. On the other hand, if this frequency
    
    // is too low, you should also increment SOFT_PWM_SCALE.
    //#define FAN_SOFT_PWM
    
    // Incrementing this by 1 will double the software PWM frequency,
    // affecting heaters, and the fan if FAN_SOFT_PWM is enabled.
    // However, control resolution will be halved for each increment;
    // at zero value, there are 128 effective control positions.
    #define SOFT_PWM_SCALE 0
    
    
    // Temperature status LEDs that display the hotend and bed temperature.
    
    // If all hotends and bed temperature and temperature setpoint are < 54C then the BLUE led is on.
    // Otherwise the RED led is on. There is 1C hysteresis.
    //#define TEMP_STAT_LEDS
    
    
    // M240  Triggers a camera by emulating a Canon RC-1 Remote
    // Data from: http://www.doc-diy.net/photo/rc-1_hacked/
    
    Richard Wackerbarth's avatar
    Richard Wackerbarth committed
    //#define PHOTOGRAPH_PIN     23
    
    // SkeinForge sends the wrong arc g-codes when using Arc Point as fillet procedure
    
    //#define SF_ARC_FIX
    
    
    // Support for the BariCUDA Paste Extruder.
    //#define BARICUDA
    
    
    //define BlinkM/CyzRgb Support
    
    // Support for an RGB LED using 3 separate pins with optional PWM
    //#define RGB_LED
    #if ENABLED(RGB_LED)
      #define RGB_LED_R_PIN 34
      #define RGB_LED_G_PIN 43
      #define RGB_LED_B_PIN 35
    #endif
    
    
    /*********************************************************************\
    * R/C SERVO support
    * Sponsored by TrinityLabs, Reworked by codexmas
    **********************************************************************/
    
    // Number of servos
    //
    // If you select a configuration below, this will receive a default value and does not need to be set manually
    // set it manually if you have more servos than extruders and wish to manually control some
    // leaving it undefined or defining as 0 will disable the servo subsystem
    // If unsure, leave commented / disabled
    //
    
    //#define NUM_SERVOS 3 // Servo index starts with 0 for M280 command
    
    // Delay (in milliseconds) before the next move will start, to give the servo time to reach its target angle.
    
    // 300ms is a good value but you can try less delay.
    // If the servo can't reach the requested position, increase it.
    #define SERVO_DELAY 300
    
    
    // Servo deactivation
    //
    // With this option servos are powered only during movement, then turned off to prevent jitter.
    //#define DEACTIVATE_SERVOS_AFTER_MOVE
    
    
    /**********************************************************************\
     * Support for a filament diameter sensor
     * Also allows adjustment of diameter at print time (vs  at slicing)
     * Single extruder only at this point (extruder 0)
    
     * 34 - RAMPS1.4 - uses Analog input 5 on the AUX2 connector
    
     * 81 - Printrboard - Uses Analog input 2 on the Exp1 connector (version B,C,D,E)
    
     * 301 - Rambo  - uses Analog input 3
     * Note may require analog pins to be defined for different motherboards
     **********************************************************************/
    
    // Uncomment below to enable
    
    //#define FILAMENT_WIDTH_SENSOR
    
    #define DEFAULT_NOMINAL_FILAMENT_DIA 3.00  //Enter the diameter (in mm) of the filament generally used (3.0 mm or 1.75 mm) - this is then used in the slicer software.  Used for sensor reading validation
    
    #if ENABLED(FILAMENT_WIDTH_SENSOR)
    
      #define FILAMENT_SENSOR_EXTRUDER_NUM 0   //The number of the extruder that has the filament sensor (0,1,2)
      #define MEASUREMENT_DELAY_CM        14   //measurement delay in cm.  This is the distance from filament sensor to middle of barrel
    
      #define MEASURED_UPPER_LIMIT         3.30  //upper limit factor used for sensor reading validation in mm
      #define MEASURED_LOWER_LIMIT         1.90  //lower limit factor for sensor reading validation in mm
      #define MAX_MEASUREMENT_DELAY       20     //delay buffer size in bytes (1 byte = 1cm)- limits maximum measurement delay allowable (must be larger than MEASUREMENT_DELAY_CM  and lower number saves RAM)
    
      #define DEFAULT_MEASURED_FILAMENT_DIA  DEFAULT_NOMINAL_FILAMENT_DIA  //set measured to nominal initially
    
      //When using an LCD, uncomment the line below to display the Filament sensor data on the last line instead of status.  Status will appear for 5 sec.
      //#define FILAMENT_LCD_DISPLAY
    #endif