summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--logo/src/xlogo/Application.java231
-rw-r--r--logo/src/xlogo/gui/Editor.java2
-rw-r--r--logo/src/xlogo/gui/HistoryPanel.java6
-rw-r--r--logo/src/xlogo/kernel/Affichage.java4
-rw-r--r--logo/src/xlogo/kernel/LaunchPrimitive.java4
5 files changed, 135 insertions, 112 deletions
diff --git a/logo/src/xlogo/Application.java b/logo/src/xlogo/Application.java
index a3fe34c..0c19b88 100644
--- a/logo/src/xlogo/Application.java
+++ b/logo/src/xlogo/Application.java
@@ -137,9 +137,10 @@ public class Application extends X4SFrame {
private DrawPanel drawPanel;
private JPanel extrasPanel;
private JSlider speedSlider;
+ private TurtleComboBox turtleCombo;
// drawingOrEditor@Editor
- public Editor editeur;
+ private Editor editor;
// Extras Menu
private JPopupMenu extras;
@@ -151,33 +152,17 @@ public class Application extends X4SFrame {
public Application() {
super();
showWelcomeMessage();
- }
-
- /**
- * Hello Username
- * You defined a, b, c, d, ...
- */
- public void showWelcomeMessage() {
- HistoryMessenger.getInstance().dispatchComment(
- translate(MessageKeys.APP_HELLO) + " " + uc.getUserName() + "!\n");
-
- StringBuilder sb = new StringBuilder();
- for (String procedureName : userSpace.getAllProcedureNames()) {
- sb.append(procedureName);
- sb.append(", ");
- }
- if (sb.length() == 0)
- return;
-
- sb.delete(sb.length() - 2, sb.length());
-
- HistoryMessenger.getInstance().dispatchComment(translate("definir") + " " + sb.toString() + ".\n");
+ focusCommandLine();
}
public JFrame getFrame() {
return mainFrame;
}
+ /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
+ * INIT
+ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
+
@Override
protected void initComponent() {
pile_historique = new Stack<String>();
@@ -201,7 +186,7 @@ public class Application extends X4SFrame {
extrasPanel = new JPanel();
speedSlider = new JSlider(JSlider.VERTICAL);
- editeur = new Editor(this);
+ editor = new Editor(this);
extras = new JPopupMenu();
@@ -231,7 +216,7 @@ public class Application extends X4SFrame {
toplevel.add(commandOrEditor, BorderLayout.CENTER);
commandOrEditor.add(commandCard, COMMAND_CARD_ID);
- commandOrEditor.add(editeur.getComponent(), EDITOR_CARD_ID);
+ commandOrEditor.add(editor.getComponent(), EDITOR_CARD_ID);
//commandOrEditor.setPreferredSize(new Dimension(d.width-200, d.height));
showCommandCard();
@@ -250,16 +235,6 @@ public class Application extends X4SFrame {
}
}
- @Override
- protected void layoutComponent() {
- layoutFilesAndProcedures();
- layoutCommandCard();
- layoutDrawingAndExtras();
- layoutDrawingArea();
- layoutExtras();
- drawPanel.getGraphics().drawImage(DrawPanel.dessin, 0, 0, mainFrame);
- }
-
private void initFrame() {
Dimension d = Toolkit.getDefaultToolkit().getScreenSize();
mainFrame.setSize(new Dimension(d.width, d.height * 9 / 10));
@@ -301,35 +276,6 @@ public class Application extends X4SFrame {
}
}
- /**
- * @author Marko Zivkovic - new impl
- */
- public void closeWindow() {
- WSManager storageManager = WSManager.getInstance();
- try {
- if (!uc.isVirtual()) {
- String openFile = userSpace.getOpenFileName();
- if (openFile != null) {
- userSpace.writeFileText(openFile, editeur.getText());
- userSpace.storeFile(openFile);
- }
- storageManager.getUserConfigInstance().store();
- }
- System.exit(0);
- }
- catch (Exception e1) {
- String message = translate(MessageKeys.US_COULD_NOT_STORE_RECENT_DATA) + "\n\n" + e1.toString() + "\n\n"
- + translate("quitter?");
-
- String[] choix = { translate(MessageKeys.DIALOG_YES), translate(MessageKeys.DIALOG_NO) };
- int retval = JOptionPane.showOptionDialog(mainFrame, message, translate("general.error.title"),
- JOptionPane.YES_NO_OPTION, JOptionPane.ERROR_MESSAGE, null, choix, choix[0]);
-
- if (retval == JOptionPane.OK_OPTION)
- System.exit(0);
- }
- }
-
private void initDrawingZone() {
// on centre la tortue
// Centering turtle
@@ -351,10 +297,14 @@ public class Application extends X4SFrame {
genere_primitive();
uc.setHeure_demarrage(Calendar.getInstance().getTimeInMillis());
setCommandLine(true);
- focus_Commande();
+ focusCommandLine();
resizeDrawingZone();
}
+ /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
+ * THEME
+ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
+
private void setTheme() {
Font font = WSManager.getWorkspaceConfig().getFont();
try {
@@ -386,6 +336,20 @@ public class Application extends X4SFrame {
UIManager.put("defaultFont", font);
}
+ /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
+ * LAYOUT
+ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
+
+ @Override
+ protected void layoutComponent() {
+ layoutFilesAndProcedures();
+ layoutCommandCard();
+ layoutDrawingAndExtras();
+ layoutDrawingArea();
+ layoutExtras();
+ drawPanel.getGraphics().drawImage(DrawPanel.dessin, 0, 0, mainFrame);
+ }
+
private void layoutFilesAndProcedures() {
// Note : the following JPanel saved my day ...
@@ -504,36 +468,18 @@ public class Application extends X4SFrame {
speedSlider.setMaximumSize(new Dimension(20, 200));
speedSlider.setValue(speedSlider.getMaximum() - uc.getTurtleSpeed());
- final TurtleComboBox turtleCombo = new TurtleComboBox();
+ turtleCombo = new TurtleComboBox();
extrasPanel.add(speedSlider);
extrasPanel.add(turtleCombo);
turtleCombo.setBackground(new Color(BG_COLOR));
turtleCombo.getComboBox().setSelectedIndex(uc.getActiveTurtle());
- turtleCombo.getComboBox().addActionListener(new ActionListener(){
-
- @Override
- public void actionPerformed(ActionEvent e) {
- int i = turtleCombo.getComboBox().getSelectedIndex();
- System.out.println(i);
- uc.setActiveTurtle(i);
- getKernel().getActiveTurtle().setShape(uc.getActiveTurtle());
- getKernel().change_image_tortue("tortue" + i + ".png");
- }
- });
-
- }
-
- public void showCommandCard() {
- CardLayout cardLayout = (CardLayout) commandOrEditor.getLayout();
- cardLayout.show(commandOrEditor, COMMAND_CARD_ID);
}
- public void showEditorCard() {
- CardLayout cardLayout = (CardLayout) commandOrEditor.getLayout();
- cardLayout.show(commandOrEditor, EDITOR_CARD_ID);
- }
+ /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
+ * EXTRAS MENU
+ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
private JMenuItem startContestMenuItem;
private JMenuItem stopContestMenuItem;
@@ -575,11 +521,13 @@ public class Application extends X4SFrame {
translate("contest.could.not.create") + "\n" + e.toString());
return;
}
+ commandLine.requestFocus();
}
});
stopContestMenuItem.addActionListener(new ActionListener(){
public void actionPerformed(ActionEvent e) {
userSpace.stopRecordMode();
+ commandLine.requestFocus();
}
});
}
@@ -615,7 +563,7 @@ public class Application extends X4SFrame {
DialogMessenger.getInstance().dispatchError(MessageKeys.GENERAL_ERROR_TITLE, e1.toString());
}
}
-
+ commandLine.requestFocus();
}
});
@@ -660,13 +608,13 @@ public class Application extends X4SFrame {
"Could not export file : \n " + e1.toString());
}
}
+ commandLine.requestFocus();
}
});
saveImage = new JMenuItem(translate(MessageKeys.US_SAVE_IMAGE));
extras.add(saveImage);
saveImage.addActionListener(new ActionListener(){
-
@Override
public void actionPerformed(ActionEvent e) {
WriteImage writeImage = new WriteImage(getFrame(), getDrawPanel().getSelectionImage());
@@ -674,6 +622,7 @@ public class Application extends X4SFrame {
if (value == JFileChooser.APPROVE_OPTION) {
writeImage.start();
}
+ commandLine.requestFocus();
}
});
}
@@ -683,15 +632,16 @@ public class Application extends X4SFrame {
return new ImageIcon(img.getScaledInstance(width, heigth, Image.SCALE_SMOOTH));
}
- /*
+ /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* CHANGE LISTENERS
- */
+ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/**
* This glues together models and the GUI controllers.
*/
@Override
protected void initEventListeners() {
+
commandLine.addMouseListener(new MouseAdapter(){
@Override
public void mousePressed(MouseEvent e) {
@@ -717,6 +667,19 @@ public class Application extends X4SFrame {
JSlider source = (JSlider) e.getSource();
int value = source.getValue();
uc.setTurtleSpeed(source.getMaximum() - value);
+ commandLine.requestFocus();
+ }
+ });
+
+ turtleCombo.getComboBox().addActionListener(new ActionListener(){
+
+ @Override
+ public void actionPerformed(ActionEvent e) {
+ int i = turtleCombo.getComboBox().getSelectedIndex();
+ uc.setActiveTurtle(i);
+ getKernel().getActiveTurtle().setShape(uc.getActiveTurtle());
+ getKernel().change_image_tortue("tortue" + i + ".png");
+ focusCommandLine();
}
});
@@ -813,7 +776,7 @@ public class Application extends X4SFrame {
@Override
public void run() {
showEditorCard();
- editeur.setText(userSpace.readFile(fileName));
+ editor.setText(userSpace.readFile(fileName));
mainFrame.setTitle(appName + " - " + uc.getUserName() + " - " + fileName);
filesList.openFile(fileName);
}
@@ -827,7 +790,7 @@ public class Application extends X4SFrame {
try {
if (userSpace.existsFile(fileName)) // It is possibly deleted, and the editor is therefore closed.
{
- userSpace.writeFileText(fileName, editeur.getText());
+ userSpace.writeFileText(fileName, editor.getText());
userSpace.storeFile(fileName);
}
}
@@ -836,7 +799,7 @@ public class Application extends X4SFrame {
translate("ws.automatic.save.failed"));
}
showCommandCard();
- commandLine.requestFocus();
+ focusCommandLine();
//commandLine.requestFocus();
mainFrame.setTitle(appName + " - " + uc.getUserName());
filesList.closeFile(fileName);
@@ -870,6 +833,7 @@ public class Application extends X4SFrame {
@Override
public void run() {
filesList.renameFile(oldName, newName);
+ focusEditor();
}
});
}
@@ -1065,6 +1029,27 @@ public class Application extends X4SFrame {
}
}
+ /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
+ * COMMANDS
+ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
+
+ public void showWelcomeMessage() {
+ HistoryMessenger.getInstance().dispatchComment(
+ translate(MessageKeys.APP_HELLO) + " " + uc.getUserName() + "!\n");
+
+ StringBuilder sb = new StringBuilder();
+ for (String procedureName : userSpace.getAllProcedureNames()) {
+ sb.append(procedureName);
+ sb.append(", ");
+ }
+ if (sb.length() == 0)
+ return;
+
+ sb.delete(sb.length() - 2, sb.length());
+
+ HistoryMessenger.getInstance().dispatchComment(translate("definir") + " " + sb.toString() + ".\n");
+ }
+
public void displayProcedure(String procedureName) {
Procedure proc = userSpace.getExecutable(procedureName);
if (proc != null)
@@ -1080,7 +1065,7 @@ public class Application extends X4SFrame {
if (openFile != null) {
try {
- userSpace.writeFileText(openFile, editeur.getText());
+ userSpace.writeFileText(openFile, editor.getText());
userSpace.storeFile(openFile);
userSpace.closeFile(openFile);
}
@@ -1090,11 +1075,57 @@ public class Application extends X4SFrame {
String fileName = proc.getOwnerName();
if (userSpace.existsFile(fileName)) {
userSpace.openFile(fileName);
- editeur.displayProcedure(proc.getName());
+ editor.displayProcedure(proc.getName());
+ }
+ }
+
+ public void showCommandCard() {
+ CardLayout cardLayout = (CardLayout) commandOrEditor.getLayout();
+ cardLayout.show(commandOrEditor, COMMAND_CARD_ID);
+ }
+
+ public void showEditorCard() {
+ CardLayout cardLayout = (CardLayout) commandOrEditor.getLayout();
+ cardLayout.show(commandOrEditor, EDITOR_CARD_ID);
+ }
+
+ public void focusCommandLine() {
+ commandLine.requestFocus();
+ }
+
+ public void focusEditor(){
+ editor.requestFocus();
+ }
+
+ public void closeWindow() {
+ WSManager storageManager = WSManager.getInstance();
+ try {
+ if (!uc.isVirtual()) {
+ String openFile = userSpace.getOpenFileName();
+ if (openFile != null) {
+ userSpace.writeFileText(openFile, editor.getText());
+ userSpace.storeFile(openFile);
+ }
+ storageManager.getUserConfigInstance().store();
+ }
+ System.exit(0);
+ }
+ catch (Exception e1) {
+ String message = translate(MessageKeys.US_COULD_NOT_STORE_RECENT_DATA) + "\n\n" + e1.toString() + "\n\n"
+ + translate("quitter?");
+
+ String[] choix = { translate(MessageKeys.DIALOG_YES), translate(MessageKeys.DIALOG_NO) };
+ int retval = JOptionPane.showOptionDialog(mainFrame, message, translate("general.error.title"),
+ JOptionPane.YES_NO_OPTION, JOptionPane.ERROR_MESSAGE, null, choix, choix[0]);
+
+ if (retval == JOptionPane.OK_OPTION)
+ System.exit(0);
}
}
- // BELOW IS MOSTLY XLOGO LEGACY CODE
+ /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
+ * BELOW IS MOSTLY XLOGO LEGACY CODE
+ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/**
* Called by the constructor or when language has been modified
@@ -1277,14 +1308,6 @@ public class Application extends X4SFrame {
}
/**
- * Set Focus on the command line
- */
- public void focus_Commande() {
- commandLine.requestFocus();
- commandLine.getCaret().setVisible(true);
- }
-
- /**
* Notice if the command line is editable.
*
* @return true if Command Line is editable, false otherwise
diff --git a/logo/src/xlogo/gui/Editor.java b/logo/src/xlogo/gui/Editor.java
index 68d2321..e6f0e3b 100644
--- a/logo/src/xlogo/gui/Editor.java
+++ b/logo/src/xlogo/gui/Editor.java
@@ -369,7 +369,7 @@ public class Editor implements ActionListener
}
}
- public void focus_textZone()
+ public void requestFocus()
{
textZone.requestFocus();
}
diff --git a/logo/src/xlogo/gui/HistoryPanel.java b/logo/src/xlogo/gui/HistoryPanel.java
index 14b2b31..530fc68 100644
--- a/logo/src/xlogo/gui/HistoryPanel.java
+++ b/logo/src/xlogo/gui/HistoryPanel.java
@@ -302,14 +302,14 @@ public class HistoryPanel extends JPanel implements HistoryWriter
select(borneinf + 1, bornesup - 2);
cadre.setCommandText(getSelectedText());
// historique.setCaretPosition(historique.getDocument().getLength());
- cadre.focus_Commande();
+ cadre.focusCommandLine();
}
}
public void mouseReleased(MouseEvent e)
{
maybeShowPopup(e);
- cadre.focus_Commande();
+ cadre.focusCommandLine();
}
public void mousePressed(MouseEvent e)
@@ -367,7 +367,7 @@ public class HistoryPanel extends JPanel implements HistoryWriter
{ // Selectionner tout
requestFocus();
selectAll();
- cadre.focus_Commande();
+ cadre.focusCommandLine();
}
else if (cmd.equals(Logo.messages.getString("menu.file.textzone.rtf")))
{
diff --git a/logo/src/xlogo/kernel/Affichage.java b/logo/src/xlogo/kernel/Affichage.java
index f1d4686..c71b0d6 100644
--- a/logo/src/xlogo/kernel/Affichage.java
+++ b/logo/src/xlogo/kernel/Affichage.java
@@ -149,7 +149,7 @@ public class Affichage extends Thread
}
cadre.setCommandLine(true);
if (!cadre.viewer3DVisible())
- cadre.focus_Commande();
+ cadre.focusCommandLine();
execution_lancee = false;
memoryChecker.kill();
cadre.error = false;
@@ -159,7 +159,7 @@ public class Affichage extends Thread
private void abortExecution()
{
- cadre.focus_Commande();
+ cadre.focusCommandLine();
cadre.error = true;
Interprete.calcul = new Stack<String>();
cadre.getKernel().getInstructionBuffer().clear();
diff --git a/logo/src/xlogo/kernel/LaunchPrimitive.java b/logo/src/xlogo/kernel/LaunchPrimitive.java
index 8c74965..aaa765e 100644
--- a/logo/src/xlogo/kernel/LaunchPrimitive.java
+++ b/logo/src/xlogo/kernel/LaunchPrimitive.java
@@ -1206,9 +1206,9 @@ public class LaunchPrimitive
donne(param);
String texte = liste + "\n" + phrase;
HistoryMessenger.getInstance().dispatchComment(Utils.SortieTexte(texte) + "\n");
- cadre.focus_Commande();
+ cadre.focusCommandLine();
lis.dispose();
- cadre.focus_Commande();
+ cadre.focusCommandLine();
break;
case 94: // touche?
Interprete.operande = true;