Skip to content

Latest commit

 

History

History
32 lines (23 loc) · 2.25 KB

README.md

File metadata and controls

32 lines (23 loc) · 2.25 KB

Class_LV_InCellEdit

AHK class providing in-cell editing for ListView controls in AHK GUIs.

The class provides methods to restrict editing to certain columns, to directly start editing of a specified cell, and to deactivate/activate the built-in message handler for WM_NOTIFY messages (see below).

The message handler for WM_NOTIFY messages will be activated for the specified ListView whenever a new instance is created. As long as the message handler is activated a double-click on any cell will show an Edit control within this cell allowing to edit the current content. The default behavior for editing the first column by two subsequent single clicks is disabled. You have to press "Esc" to cancel editing, otherwise the content of the Edit will be stored in the current cell. ListViews must have the -ReadOnly option to be editable.

While editing, "Esc", "Tab", "Shift+Tab", "Down", and "Up" keys are registered as hotkeys. "Esc" will cancel editing without changing the value of the current cell. All other hotkeys will store the content of the edit in the current cell and continue editing for the next (Tab), previous (Shift+Tab), upper (Up), or lower (Down) cell. You cannot use the keys for other purposes while editing.

All changes are stored in MyInstance.Changed. You may track the changes by triggering (A_GuiEvent == "F") in the ListView's gLabel and checking MyInstance["Changed"] as shown in the sample scipt. If "True", MyInstance.Changed contains an array of objects with keys "Row" (row number), "Col" (column number), and "Txt" (new content). 'Changed' is one of the two keys intended to be accessed directly from outside the class.

If you want to temporarily disable in-cell editing call MyInstance.OnMessage(False). This must be done also before you try to destroy the instance. To enable it again, call `MyInstance.OnMessage()``.

To avoid the loss of Gui events and messages the message handler might need to be Critical. This can be achieved by setting the instance property 'Critical' to the required value (e.g. MyInstance.Critical := 100). New instances default to Critical, Off. Though sometimes needed, ListViews or the whole Gui may become unresponsive under certain circumstances if Critical is set and the ListView has a g-label.