Skip to content

Commit

Permalink
Fix Scrolling while Zooming,
Browse files Browse the repository at this point in the history
Ctrl inhibits scroll functions in RScrollPane
Addresses #53
  • Loading branch information
deathmarine committed Jul 26, 2016
1 parent 9290349 commit 2dee06a
Show file tree
Hide file tree
Showing 2 changed files with 224 additions and 35 deletions.
62 changes: 37 additions & 25 deletions src/us/deathmarine/luyten/JFontChooser.java
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,10 @@
* <pre>
**/
public class JFontChooser extends JComponent {
/**
*
*/
private static final long serialVersionUID = 8856126034081661L;
// class variables
/**
* Return value from <code>showDialog()</code>.
Expand Down Expand Up @@ -83,20 +87,20 @@ public class JFontChooser extends JComponent {
// instance variables
protected int dialogResultValue = ERROR_OPTION;

private String[] fontStyleNames = null;
private String[] fontFamilyNames = null;
private String[] fontSizeStrings = null;
private JTextField fontFamilyTextField = null;
private JTextField fontStyleTextField = null;
private JTextField fontSizeTextField = null;
private JList fontNameList = null;
private JList fontStyleList = null;
private JList fontSizeList = null;
private JPanel fontNamePanel = null;
private JPanel fontStylePanel = null;
private JPanel fontSizePanel = null;
private JPanel samplePanel = null;
private JTextField sampleText = null;
private String[] fontStyleNames;
private String[] fontFamilyNames;
private String[] fontSizeStrings;
private JTextField fontFamilyTextField;
private JTextField fontStyleTextField;
private JTextField fontSizeTextField;
private JList<?> fontNameList;
private JList<?> fontStyleList;
private JList<?> fontSizeList;
private JPanel fontNamePanel;
private JPanel fontStylePanel;
private JPanel fontSizePanel;
private JPanel samplePanel;
private JTextField sampleText;

/**
* Constructs a <code>JFontChooser</code> object.
Expand Down Expand Up @@ -172,9 +176,9 @@ public JTextField getFontSizeTextField() {
return fontSizeTextField;
}

public JList getFontFamilyList() {
public JList<?> getFontFamilyList() {
if (fontNameList == null) {
fontNameList = new JList(getFontFamilies());
fontNameList = new JList<Object>(getFontFamilies());
fontNameList.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
fontNameList.addListSelectionListener(new ListSelectionHandler(getFontFamilyTextField()));
fontNameList.setSelectedIndex(0);
Expand All @@ -184,9 +188,9 @@ public JList getFontFamilyList() {
return fontNameList;
}

public JList getFontStyleList() {
public JList<?> getFontStyleList() {
if (fontStyleList == null) {
fontStyleList = new JList(getFontStyleNames());
fontStyleList = new JList<Object>(getFontStyleNames());
fontStyleList.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
fontStyleList.addListSelectionListener(new ListSelectionHandler(getFontStyleTextField()));
fontStyleList.setSelectedIndex(0);
Expand All @@ -196,9 +200,9 @@ public JList getFontStyleList() {
return fontStyleList;
}

public JList getFontSizeList() {
public JList<?> getFontSizeList() {
if (fontSizeList == null) {
fontSizeList = new JList(this.fontSizeStrings);
fontSizeList = new JList<Object>(this.fontSizeStrings);
fontSizeList.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
fontSizeList.addListSelectionListener(new ListSelectionHandler(getFontSizeTextField()));
fontSizeList.setSelectedIndex(0);
Expand Down Expand Up @@ -390,7 +394,7 @@ protected class ListSelectionHandler implements ListSelectionListener {

public void valueChanged(ListSelectionEvent e) {
if (e.getValueIsAdjusting() == false) {
JList list = (JList) e.getSource();
JList<?> list = (JList<?>) e.getSource();
String selectedValue = (String) list.getSelectedValue();

String oldValue = textComponent.getText();
Expand Down Expand Up @@ -423,9 +427,9 @@ public void focusLost(FocusEvent e) {
}

protected class TextFieldKeyHandlerForListSelectionUpDown extends KeyAdapter {
private JList targetList;
private JList<?> targetList;

public TextFieldKeyHandlerForListSelectionUpDown(JList list) {
public TextFieldKeyHandlerForListSelectionUpDown(JList<?> list) {
this.targetList = list;
}

Expand Down Expand Up @@ -454,9 +458,9 @@ public void keyPressed(KeyEvent e) {
}

protected class ListSearchTextFieldDocumentHandler implements DocumentListener {
JList targetList;
JList<?> targetList;

public ListSearchTextFieldDocumentHandler(JList targetList) {
public ListSearchTextFieldDocumentHandler(JList<?> targetList) {
this.targetList = targetList;
}

Expand Down Expand Up @@ -511,6 +515,10 @@ public void run() {
}

protected class DialogOKAction extends AbstractAction {
/**
*
*/
private static final long serialVersionUID = 1618273732543947323L;
protected static final String ACTION_NAME = "OK";
private JDialog dialog;

Expand All @@ -528,6 +536,10 @@ public void actionPerformed(ActionEvent e) {
}

protected class DialogCancelAction extends AbstractAction {
/**
*
*/
private static final long serialVersionUID = -4941763616565382601L;
protected static final String ACTION_NAME = "Cancel";
private JDialog dialog;

Expand Down
197 changes: 187 additions & 10 deletions src/us/deathmarine/luyten/OpenFile.java
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
package us.deathmarine.luyten;

import java.awt.Component;
import java.awt.Cursor;
import java.awt.Font;
import java.awt.Panel;
import java.awt.PopupMenu;
import java.awt.Rectangle;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
Expand All @@ -15,21 +15,21 @@
import java.awt.event.MouseWheelEvent;
import java.awt.event.MouseWheelListener;
import java.io.StringWriter;
import java.lang.reflect.Field;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
import java.util.concurrent.ConcurrentHashMap;

import javax.swing.JDialog;
import javax.swing.JLabel;
import javax.swing.JMenuItem;
import javax.swing.JPopupMenu;
import javax.swing.JScrollBar;
import javax.swing.JScrollPane;
import javax.swing.JViewport;
import javax.swing.ScrollPaneConstants;
import javax.swing.Scrollable;
import javax.swing.SwingConstants;
import javax.swing.SwingUtilities;
import javax.swing.event.HyperlinkEvent;
import org.fife.ui.rsyntaxtextarea.LinkGenerator;
Expand Down Expand Up @@ -154,6 +154,7 @@ else if (name.toLowerCase().endsWith(".py"))
public void actionPerformed(ActionEvent e) {
JFontChooser fontChooser = new JFontChooser();
fontChooser.setSelectedFont(textArea.getFont());
fontChooser.setSelectedFontSize(textArea.getFont().getSize());
int result = fontChooser.showDialog(mainWindow);
if (result == JFontChooser.OK_OPTION)
textArea.setFont(fontChooser.getSelectedFont());
Expand Down Expand Up @@ -211,19 +212,195 @@ public int getSourceOffset() {
}
});

//Add Ctrl+Wheel Zoom for Text Size
/*
* Add Ctrl+Wheel Zoom for Text Size
* Removes all standard listeners and writes new listeners for wheelscroll movement.
*/
for(MouseWheelListener listeners :scrollPane.getMouseWheelListeners()){
scrollPane.removeMouseWheelListener(listeners);
};
scrollPane.addMouseWheelListener(new MouseWheelListener(){
@Override
public void mouseWheelMoved(MouseWheelEvent e) {

if ((e.getModifiersEx() & InputEvent.CTRL_DOWN_MASK) != 0){
Font font = textArea.getFont();
int size = font.getSize();
if(e.getWheelRotation() > 0){ //Down
textArea.setFont(new Font(font.getName(), font.getStyle(), ++size));
}else{
textArea.setFont(new Font(font.getName(), font.getStyle(), --size >= 2 ? --size : 2));
if(e.getWheelRotation() > 0){
textArea.setFont(new Font(font.getName(), font.getStyle(), --size >= 8 ? --size : 8));
}else{
textArea.setFont(new Font(font.getName(), font.getStyle(), ++size));
}
}
}else{
if (scrollPane.isWheelScrollingEnabled() &&
e.getWheelRotation() != 0) {
JScrollBar toScroll = scrollPane.getVerticalScrollBar();
int direction = e.getWheelRotation() < 0 ? -1 : 1;
int orientation = SwingConstants.VERTICAL;
if (toScroll == null || !toScroll.isVisible()) {
toScroll = scrollPane.getHorizontalScrollBar();
if (toScroll == null || !toScroll.isVisible()) {
return;
}
orientation = SwingConstants.HORIZONTAL;
}
e.consume();

if (e.getScrollType() == MouseWheelEvent.WHEEL_UNIT_SCROLL) {
JViewport vp = scrollPane.getViewport();
if (vp == null) {
return;
}
Component comp = vp.getView();
int units = Math.abs(e.getUnitsToScroll());
boolean limitScroll = Math.abs(e.getWheelRotation()) == 1;
Object fastWheelScroll = toScroll.getClientProperty(
"JScrollBar.fastWheelScrolling");
if (Boolean.TRUE == fastWheelScroll &&
comp instanceof Scrollable) {
Scrollable scrollComp = (Scrollable) comp;
Rectangle viewRect = vp.getViewRect();
int startingX = viewRect.x;
boolean leftToRight =
comp.getComponentOrientation().isLeftToRight();
int scrollMin = toScroll.getMinimum();
int scrollMax = toScroll.getMaximum() -
toScroll.getModel().getExtent();

if (limitScroll) {
int blockIncr =
scrollComp.getScrollableBlockIncrement(viewRect,
orientation,
direction);
if (direction < 0) {
scrollMin = Math.max(scrollMin,
toScroll.getValue() - blockIncr);
}
else {
scrollMax = Math.min(scrollMax,
toScroll.getValue() + blockIncr);
}
}

for (int i = 0; i < units; i++) {
int unitIncr =
scrollComp.getScrollableUnitIncrement(viewRect,
orientation, direction);
if (orientation == SwingConstants.VERTICAL) {
if (direction < 0) {
viewRect.y -= unitIncr;
if (viewRect.y <= scrollMin) {
viewRect.y = scrollMin;
break;
}
}
else { // (direction > 0
viewRect.y += unitIncr;
if (viewRect.y >= scrollMax) {
viewRect.y = scrollMax;
break;
}
}
}
else {
if ((leftToRight && direction < 0) ||
(!leftToRight && direction > 0)) {
viewRect.x -= unitIncr;
if (leftToRight) {
if (viewRect.x < scrollMin) {
viewRect.x = scrollMin;
break;
}
}
}
else if ((leftToRight && direction > 0) ||
(!leftToRight && direction < 0)) {
viewRect.x += unitIncr;
if (leftToRight) {
if (viewRect.x > scrollMax) {
viewRect.x = scrollMax;
break;
}
}
}
else {
assert false : "Non-sensical ComponentOrientation / scroll direction";
}
}
}
if (orientation == SwingConstants.VERTICAL) {
toScroll.setValue(viewRect.y);
}
else {
if (leftToRight) {
toScroll.setValue(viewRect.x);
}
else {
int newPos = toScroll.getValue() -
(viewRect.x - startingX);
if (newPos < scrollMin) {
newPos = scrollMin;
}
else if (newPos > scrollMax) {
newPos = scrollMax;
}
toScroll.setValue(newPos);
}
}
} else {
int delta;
int limit = -1;

if (limitScroll) {
if (direction < 0) {
limit = toScroll.getValue() - toScroll.getBlockIncrement(direction);
} else {
limit = toScroll.getValue() + toScroll.getBlockIncrement(direction);
}
}

for (int i = 0; i < units; i++) {
if (direction > 0) {
delta = toScroll.getUnitIncrement(direction);
} else {
delta = -toScroll.getUnitIncrement(direction);
}
int oldValue = toScroll.getValue();
int newValue = oldValue + delta;
if (delta > 0 && newValue < oldValue) {
newValue = toScroll.getMaximum();
} else if (delta < 0 && newValue > oldValue) {
newValue = toScroll.getMinimum();
}
if (oldValue == newValue) {
break;
}
if (limitScroll && i > 0) {
assert limit != -1;
if ((direction < 0 && newValue < limit)
|| (direction > 0 && newValue > limit)) {
break;
}
}
toScroll.setValue(newValue);
}

}
} else if (e.getScrollType() == MouseWheelEvent.WHEEL_BLOCK_SCROLL) {
int oldValue = toScroll.getValue();
int blockIncrement = toScroll.getBlockIncrement(direction);
int delta = blockIncrement * ((direction > 0) ? +1 : -1);
int newValue = oldValue + delta;
if (delta > 0 && newValue < oldValue) {
newValue = toScroll.getMaximum();
}
else if (delta < 0 && newValue > oldValue) {
newValue = toScroll.getMinimum();
}
toScroll.setValue(newValue);
}
}
}
e.consume();
}
});
Expand Down

0 comments on commit 2dee06a

Please sign in to comment.