From b797c2778bd839cadcb4f594408bc693d5d79117 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Axel=20D=C3=B6rfler?= Date: Wed, 18 Feb 2004 12:26:18 +0000 Subject: [PATCH] The cursor position is now correctly maintained in the HeaderView as well. git-svn-id: file:///srv/svn/repos/haiku/trunk/current@6631 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- src/apps/diskprobe/DataView.cpp | 7 +++++++ src/apps/diskprobe/DataView.h | 1 + src/apps/diskprobe/ProbeView.cpp | 18 ++++++++++++++++++ 3 files changed, 26 insertions(+) diff --git a/src/apps/diskprobe/DataView.cpp b/src/apps/diskprobe/DataView.cpp index 96c9100e00..030892ac22 100644 --- a/src/apps/diskprobe/DataView.cpp +++ b/src/apps/diskprobe/DataView.cpp @@ -416,6 +416,13 @@ DataView::SetSelection(int32 start, int32 end, view_focus focus) return; } + // notify our listeners + if (fStart != start) { + BMessage update; + update.AddInt64("position", start); + SendNotices(kDataViewCursorPosition, &update); + } + // remove old selection // ToDo: this could be drastically improved if only the changed // parts are drawn! Of course, this would only work for the diff --git a/src/apps/diskprobe/DataView.h b/src/apps/diskprobe/DataView.h index 171749b835..4c528e86f5 100644 --- a/src/apps/diskprobe/DataView.h +++ b/src/apps/diskprobe/DataView.h @@ -14,6 +14,7 @@ class DataEditor; static const uint32 kMsgBaseType = 'base'; +static const uint32 kDataViewCursorPosition = 'curs'; enum base_type { kHexBase, diff --git a/src/apps/diskprobe/ProbeView.cpp b/src/apps/diskprobe/ProbeView.cpp index ad16688b92..7174857bb9 100644 --- a/src/apps/diskprobe/ProbeView.cpp +++ b/src/apps/diskprobe/ProbeView.cpp @@ -530,6 +530,23 @@ void HeaderView::MessageReceived(BMessage *message) { switch (message->what) { + case B_OBSERVER_NOTICE_CHANGE: { + int32 what; + if (message->FindInt32(B_OBSERVE_WHAT_CHANGE, &what) != B_OK) + break; + + switch (what) { + case kDataViewCursorPosition: + off_t offset; + if (message->FindInt64("position", &offset) == B_OK) { + fOffset = offset; + UpdateOffsetViews(fPositionSlider->Position()); + } + break; + } + break; + } + case kMsgSliderUpdate: { off_t position = fPositionSlider->Position(); @@ -642,6 +659,7 @@ void ProbeView::AttachedToWindow() { fEditor.StartWatching(this); + fDataView->StartWatching(fHeaderView, kDataViewCursorPosition); // Add menu to window