com.willwinder.universalgcodesender.model.BackendAPI Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ugs-core- Show documentation
Show all versions of ugs-core- Show documentation
Universal Gcode Sender Library
The newest version!
/*
Copyright 2015-2018 Will Winder
This file is part of Universal Gcode Sender (UGS).
UGS is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
UGS is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with UGS. If not, see .
*/
package com.willwinder.universalgcodesender.model;
import com.willwinder.universalgcodesender.IController;
import com.willwinder.universalgcodesender.gcode.GcodeParser;
import com.willwinder.universalgcodesender.listeners.MessageListener;
import com.willwinder.universalgcodesender.listeners.MessageType;
import com.willwinder.universalgcodesender.types.GcodeCommand;
import com.willwinder.universalgcodesender.utils.Settings;
import com.willwinder.universalgcodesender.model.UnitUtils.Units;
import java.io.File;
/**
* API used by front ends to interface with the model.
*/
public interface BackendAPI extends BackendAPIReadOnly {
// Config options
void setGcodeFile(File file) throws Exception;
void applySettings(Settings settings) throws Exception;
/**
* Modify the currently processed gcode with a provided gcode parser.
* This can be used for post-processing tasks like rotating a gcode file.
* @param gcp externally configured gcode parser.
* @throws Exception
*/
void applyGcodeParser(GcodeParser gcp) throws Exception;
/**
* Process the currently loaded gcode file and export it to a file.
* Intended primarily as "save and export" style preprocessor option.
* @param f location to export processed gcode
*/
void preprocessAndExportToFile(File f) throws Exception;
// Control options
void connect(String firmware, String port, int baudRate) throws Exception;
void disconnect() throws Exception;
void sendGcodeCommand(String commandText) throws Exception;
void sendGcodeCommand(boolean restoreParserState, String commandText) throws Exception;
void sendGcodeCommand(GcodeCommand command) throws Exception;
void adjustManualLocation(int dirX, int dirY, int dirZ, double stepSize, double feedRate, Units units) throws Exception;
void probe(String axis, double feedRate, double distance, UnitUtils.Units units) throws Exception;
void offsetTool(String axis, double offset, UnitUtils.Units units) throws Exception;
void send() throws Exception;
void pauseResume() throws Exception;
void cancel() throws Exception;
void returnToZero() throws Exception;
void resetCoordinatesToZero() throws Exception;
void resetCoordinateToZero(Axis coordinate) throws Exception;
/**
* Sets the work position for a given axis to a position.
*
* @param axis the axis to change
* @param position the position to set the axis to.
* @throws Exception
*/
void setWorkPosition(Axis axis, double position) throws Exception;
/**
* Sets the work position for a given axis to a position defined by an mathimatical
* expression. The character '#' will be replaced by the current work position. If the
* expression starts with '/' or '*' the expression will be prepended with the current
* work position.
*
* Examples:
* 20 * 2 + 0.05
* # / 2
* * 2
*
* @param axis the axis to set
* @param expression the mathimatical expression to use
*/
void setWorkPositionUsingExpression(Axis axis, String expression) throws Exception;
void killAlarmLock() throws Exception;
void performHomingCycle() throws Exception;
void toggleCheckMode() throws Exception;
void issueSoftReset() throws Exception;
void requestParserState() throws Exception;
// Programatically call an override.
void sendOverrideCommand(Overrides override) throws Exception;
// Shouldn't be needed often.
IController getController();
void applySettingsToController(Settings settings, IController controller) throws Exception;
/**
* Dispatch a message with the given type to all registered message listeners using {@link MessageListener#onMessage(MessageType, String)}
*
* @param messageType the type of message to be printed
* @param message the message to be written
*/
void dispatchMessage(MessageType messageType, String message);
}