aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSiva Velusamy <vsiva@google.com>2012-10-01 17:08:05 -0700
committerSiva Velusamy <vsiva@google.com>2012-10-01 17:46:45 -0700
commit5b8be6e373ecd71d5743f07ed781cd7141928db4 (patch)
tree7ed8f70d20c70c3e24598efe26af1dac17b2c2ec
parent4caaf5a119a92faa7a9ef91c3e53c67491686140 (diff)
downloadsdk-5b8be6e373ecd71d5743f07ed781cd7141928db4.zip
sdk-5b8be6e373ecd71d5743f07ed781cd7141928db4.tar.gz
sdk-5b8be6e373ecd71d5743f07ed781cd7141928db4.tar.bz2
logcat: Only listen to user generated scroll events
Scrolling behavior should not be altered when the scroll bar location changes due to the addition of new messages. Change-Id: Id38deb9f17d6d58bea6f25b33fed23c887c5cc5d
-rw-r--r--ddms/libs/ddmuilib/src/com/android/ddmuilib/logcat/LogCatPanel.java58
1 files changed, 52 insertions, 6 deletions
diff --git a/ddms/libs/ddmuilib/src/com/android/ddmuilib/logcat/LogCatPanel.java b/ddms/libs/ddmuilib/src/com/android/ddmuilib/logcat/LogCatPanel.java
index 9f38b29..4f27f02 100644
--- a/ddms/libs/ddmuilib/src/com/android/ddmuilib/logcat/LogCatPanel.java
+++ b/ddms/libs/ddmuilib/src/com/android/ddmuilib/logcat/LogCatPanel.java
@@ -51,6 +51,7 @@ import org.eclipse.swt.events.ModifyEvent;
import org.eclipse.swt.events.ModifyListener;
import org.eclipse.swt.events.SelectionAdapter;
import org.eclipse.swt.events.SelectionEvent;
+import org.eclipse.swt.events.SelectionListener;
import org.eclipse.swt.graphics.Color;
import org.eclipse.swt.graphics.Font;
import org.eclipse.swt.graphics.FontData;
@@ -177,6 +178,11 @@ public final class LogCatPanel extends SelectionDependentPanel
private ToolItem mScrollLockCheckBox;
private boolean mAutoScrollLock;
+ // Lock under which the vertical scroll bar listener should be added
+ private final Object mScrollBarSelectionListenerLock = new Object();
+ private SelectionListener mScrollBarSelectionListener;
+ private boolean mScrollBarListenerSet = false;
+
private String mLogFileExportFolder;
private Font mFont;
@@ -916,18 +922,28 @@ public final class LogCatPanel extends SelectionDependentPanel
});
final ScrollBar vbar = mTable.getVerticalBar();
- vbar.addSelectionListener(new SelectionAdapter() {
+ mScrollBarSelectionListener = new SelectionAdapter() {
@Override
public void widgetSelected(SelectionEvent e) {
if (!mAutoScrollLock) {
return;
}
- boolean isAtBottom = (vbar.getThumb() + vbar.getSelection()) == vbar.getMaximum();
- setScrollToLatestLog(isAtBottom);
- mScrollLockCheckBox.setSelection(isAtBottom);
+ // thumb + selection < max => bar is not at the bottom.
+ // We subtract an arbitrary amount (thumbSize/2) from this difference to allow
+ // for cases like half a line being displayed at the end from affecting this
+ // calculation. The thumbSize/2 number seems to work experimentally across
+ // Linux/Mac & Windows, but might possibly need tweaking.
+ int diff = vbar.getThumb() + vbar.getSelection() - vbar.getMaximum();
+ boolean isAtBottom = Math.abs(diff) < vbar.getThumb() / 2;
+
+ if (isAtBottom != mShouldScrollToLatestLog) {
+ setScrollToLatestLog(isAtBottom);
+ mScrollLockCheckBox.setSelection(isAtBottom);
+ }
}
- });
+ };
+ startScrollBarMonitor(vbar);
// Explicitly set the values to use for the scroll bar. In particular, we want these values
// to have a high enough accuracy that even small movements of the scroll bar have an
@@ -943,6 +959,24 @@ public final class LogCatPanel extends SelectionDependentPanel
THUMB); // page increment
}
+ private void startScrollBarMonitor(ScrollBar vbar) {
+ synchronized (mScrollBarSelectionListenerLock) {
+ if (!mScrollBarListenerSet) {
+ mScrollBarListenerSet = true;
+ vbar.addSelectionListener(mScrollBarSelectionListener);
+ }
+ }
+ }
+
+ private void stopScrollBarMonitor(ScrollBar vbar) {
+ synchronized (mScrollBarSelectionListenerLock) {
+ if (mScrollBarListenerSet) {
+ mScrollBarListenerSet = false;
+ vbar.removeSelectionListener(mScrollBarSelectionListener);
+ }
+ }
+ }
+
/** Setup menu to be displayed when right clicking a log message. */
private void addRightClickMenu(final Table table) {
// This action will pop up a create filter dialog pre-populated with current selection
@@ -1013,7 +1047,6 @@ public final class LogCatPanel extends SelectionDependentPanel
private void setScrollToLatestLog(boolean scroll) {
mShouldScrollToLatestLog = scroll;
-
if (scroll) {
scrollToLatestLog();
}
@@ -1209,6 +1242,10 @@ public final class LogCatPanel extends SelectionDependentPanel
mTable.setRedraw(false);
+ // the scroll bar should only listen to user generated scroll events, not the
+ // scroll events that happen due to the addition of logs
+ stopScrollBarMonitor(mTable.getVerticalBar());
+
// Obtain the list of new messages, and the number of deleted messages.
List<LogCatMessage> newMessages;
int deletedMessageCount;
@@ -1285,6 +1322,15 @@ public final class LogCatPanel extends SelectionDependentPanel
}
mTable.setRedraw(true);
+
+ // re-enable listening to scroll bar events, but do so in a separate thread to make
+ // sure that the current task (LogCatRefresherTask) has completed first
+ Display.getDefault().asyncExec(new Runnable() {
+ @Override
+ public void run() {
+ startScrollBarMonitor(mTable.getVerticalBar());
+ }
+ });
}
/**