Recent

Author Topic: Keeping a single level of a TreeView sorted  (Read 838 times)

MarkMLl

  • Hero Member
  • *****
  • Posts: 7516
Keeping a single level of a TreeView sorted
« on: July 10, 2024, 08:57:49 pm »
What is recommended practice for keeping a single level (level 1 out of 0-1-2) of a TreeView which is getting a lot of program-driven updates (add-move-delete plus text changes at levels 1 and 2) sorted?

The user won't be changing anything but might be expanding/shrinking level 0 and 1 nodes to see their content.

At some point the selected node might be significant, to mark that detail be displayed elsewhere in the window.

MarkMLl
MT+86 & Turbo Pascal v1 on CCP/M-86, multitasking with LAN & graphics in 128Kb.
Logitech, TopSpeed & FTL Modula-2 on bare metal (Z80, '286 protected mode).
Pet hate: people who boast about the size and sophistication of their computer.
GitHub repositories: https://github.com/MarkMLl?tab=repositories

jamie

  • Hero Member
  • *****
  • Posts: 6529
Re: Keeping a single level of a TreeView sorted
« Reply #1 on: July 11, 2024, 03:54:37 am »
I think you should be building those nodes off the side then do a complete update of said nodes while blocking the user in the process.

I found things don't go well when user is interacting with the treeview at times while background updates to the nodes are taking place.
The only true wisdom is knowing you know nothing

cdbc

  • Hero Member
  • *****
  • Posts: 1499
    • http://www.cdbc.dk
Re: Keeping a single level of a TreeView sorted
« Reply #2 on: July 11, 2024, 08:14:52 am »
Hi
I'm doing my inserts into the tree sorted by/in code, no direct interaction from the user. (S)He can choose, collapse & expand nodes, but for addition & deletion (s)he gets an 'inputbox' or 'messagedlg' and I do the insertion or deletion in code.
At the same time I'm also employing @jamie's technique... sort of beginupdate/endupdate style...
Regards Benny
If it ain't broke, don't fix it ;)
PCLinuxOS(rolling release) 64bit -> KDE5 -> FPC 3.2.2 -> Lazarus 2.2.6 up until Jan 2024 from then on it's: KDE5/QT5 -> FPC 3.3.1 -> Lazarus 3.0

MarkMLl

  • Hero Member
  • *****
  • Posts: 7516
Re: Keeping a single level of a TreeView sorted
« Reply #3 on: July 11, 2024, 08:33:53 am »
Yes, that's pretty much what I'm doing. The TreeView is there to display to the user, not as a primary means of data entry or manipulation.

MarkMLl
MT+86 & Turbo Pascal v1 on CCP/M-86, multitasking with LAN & graphics in 128Kb.
Logitech, TopSpeed & FTL Modula-2 on bare metal (Z80, '286 protected mode).
Pet hate: people who boast about the size and sophistication of their computer.
GitHub repositories: https://github.com/MarkMLl?tab=repositories

cdbc

  • Hero Member
  • *****
  • Posts: 1499
    • http://www.cdbc.dk
Re: Keeping a single level of a TreeView sorted
« Reply #4 on: July 11, 2024, 09:01:12 am »
Hi
Yeah Mark, that's exactly my view on the matter too...
Plus, I haven't yet come around to familiarize myself with this 'Virtual mode'...
Regards Benny
If it ain't broke, don't fix it ;)
PCLinuxOS(rolling release) 64bit -> KDE5 -> FPC 3.2.2 -> Lazarus 2.2.6 up until Jan 2024 from then on it's: KDE5/QT5 -> FPC 3.3.1 -> Lazarus 3.0

MarkMLl

  • Hero Member
  • *****
  • Posts: 7516
Re: Keeping a single level of a TreeView sorted
« Reply #5 on: July 11, 2024, 11:47:35 am »
I've been wrestling with interactions over the last few days, but think I've got things sorted by now. Incoming contact blips, a callback to code to add/move/update/delete traffic slips in a TreeView, depending on what happens there the blip is either added to a cache or used to update an existing entry.

The tricky bit centres around a CustomDraw to handle colours, since that relies on a TreeNode.Data pointer to a blip... so it's vitally important to know whether it's been cached or deleted (which would of course be a serious error).

Central to that is being absolutely sure that all TreeView operations have, in fact, been completed before cases where a blip is copied into an existing cache entry and deleted. I'm not sure whether there is a simple "MessageQueue is non-empty" test, but I might add an extra IdleTimer which does nothing but update an activity counter indicating that no further APMs are needed.

I'm still interested in anybody's thoughts on single-level node sorting, but meanwhile am moving on to displaying map overlays using a facility that Alpine has recently added to LazMapViewer.

MarkMLl
MT+86 & Turbo Pascal v1 on CCP/M-86, multitasking with LAN & graphics in 128Kb.
Logitech, TopSpeed & FTL Modula-2 on bare metal (Z80, '286 protected mode).
Pet hate: people who boast about the size and sophistication of their computer.
GitHub repositories: https://github.com/MarkMLl?tab=repositories

 

TinyPortal © 2005-2018