Jump to content

listview edit udf


Kanashius
 Share

Recommended Posts

Awesome.

Thanks for sharing.

 

Signature beginning:
Please remember: "AutoIt"..... *  Wondering who uses AutoIt and what it can be used for ? * Forum Rules *
ADO.au3 UDF * POP3.au3 UDF * XML.au3 UDF * IE on Windows 11 * How to ask ChatGPT for AutoIt Codefor other useful stuff click the following button:

Spoiler

Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind. 

My contribution (my own projects): * Debenu Quick PDF Library - UDF * Debenu PDF Viewer SDK - UDF * Acrobat Reader - ActiveX Viewer * UDF for PDFCreator v1.x.x * XZip - UDF * AppCompatFlags UDF * CrowdinAPI UDF * _WinMergeCompare2Files() * _JavaExceptionAdd() * _IsBeta() * Writing DPI Awareness App - workaround * _AutoIt_RequiredVersion() * Chilkatsoft.au3 UDF * TeamViewer.au3 UDF * JavaManagement UDF * VIES over SOAP * WinSCP UDF * GHAPI UDF - modest begining - comunication with GitHub REST APIErrorLog.au3 UDF - A logging Library * Include Dependency Tree (Tool for analyzing script relations) * Show_Macro_Values.au3 *

 

My contribution to others projects or UDF based on  others projects: * _sql.au3 UDF  * POP3.au3 UDF *  RTF Printer - UDF * XML.au3 UDF * ADO.au3 UDF SMTP Mailer UDF * Dual Monitor resolution detection * * 2GUI on Dual Monitor System * _SciLexer.au3 UDF * SciTE - Lexer for console pane

Useful links: * Forum Rules * Forum etiquette *  Forum Information and FAQs * How to post code on the forum * AutoIt Online Documentation * AutoIt Online Beta Documentation * SciTE4AutoIt3 getting started * Convert text blocks to AutoIt code * Games made in Autoit * Programming related sites * Polish AutoIt Tutorial * DllCall Code Generator * 

Wiki: Expand your knowledge - AutoIt Wiki * Collection of User Defined Functions * How to use HelpFile * Good coding practices in AutoIt * 

OpenOffice/LibreOffice/XLS Related: WriterDemo.au3 * XLS/MDB from scratch with ADOX

IE Related:  * How to use IE.au3  UDF with  AutoIt v3.3.14.x * Why isn't Autoit able to click a Javascript Dialog? * Clicking javascript button with no ID * IE document >> save as MHT file * IETab Switcher (by LarsJ ) * HTML Entities * _IEquerySelectorAll() (by uncommon) * IE in TaskSchedulerIE Embedded Control Versioning (use IE9+ and HTML5 in a GUI) * PDF Related:How to get reference to PDF object embeded in IE * IE on Windows 11

I encourage you to read: * Global Vars * Best Coding Practices * Please explain code used in Help file for several File functions * OOP-like approach in AutoIt * UDF-Spec Questions *  EXAMPLE: How To Catch ConsoleWrite() output to a file or to CMD *

I also encourage you to check awesome @trancexx code:  * Create COM objects from modules without any demand on user to register anything. * Another COM object registering stuffOnHungApp handlerAvoid "AutoIt Error" message box in unknown errors  * HTML editor

winhttp.au3 related : * https://www.autoitscript.com/forum/topic/206771-winhttpau3-download-problem-youre-speaking-plain-http-to-an-ssl-enabled-server-port/

"Homo sum; humani nil a me alienum puto" - Publius Terentius Afer
"Program are meant to be read by humans and only incidentally for computers and execute" - Donald Knuth, "The Art of Computer Programming"
:naughty:  :ranting:, be  :) and       \\//_.

Anticipating Errors :  "Any program that accepts data from a user must include code to validate that data before sending it to the data store. You cannot rely on the data store, ...., or even your programming language to notify you of problems. You must check every byte entered by your users, making sure that data is the correct type for its field and that required fields are not empty."

Signature last update: 2023-04-24

Link to comment
Share on other sites

  • 1 year later...

Kanashius,

I am using your ListView Editing scripts, and I love it! Thank you so much for sharing this.

One thing I am trying to modify is to trap the TAB key in Edit mode, save the current Input, and focus on the next field to the right, opening it in Edit mode. If we are at the right-most field, then just act like the ENTER key was pressed. I have been through your scripts over and over, trying different ways, but I can't seem to capture the TAB key and make this happen. Any ideas on how to go about this?

 

Thanks in advance for your assistance!

Link to comment
Share on other sites

I changed some functions and wrote some new, now its possible, what you want to do :)

Changed:
    __ListViewEditInput_InitializeKeys: Its now possile to add an Array with Accelerators when initializing
    __ListViewEditInput_WM_NOTIFY: outsourced Quellcode to another Function (__ListViewEditInput__EditItem)
Added:
    __ListViewEditInput_GetEditedCell: Returns the Ctrl,index and subindex of last edited/actual editing cell
    __ListViewEditInput__EditItem: Set Cell to edit, needs listviewcontrol, itemindex and subitemindex

For testing I wrote an Example.

Interesting for you is Line 14-16 and 45-52

MfG Kanashius :shifty:

Example_wingnut.au3

ListViewEditInput.au3

Link to comment
Share on other sites

Hello again.

I reworked this UDF with maps and structs and a more simple way to interact with.

It now supports switching to the next cell with "TAB". Cancel with "ESC" and save with "ENTER" still works.

I updated the start post :)

PS: When changing the edited cell with the "Tab" key; the visuals of the cell are not correct until the mouse is moved over the cell... I have no idea what is happening there and tried to mitigate that with a window redraw of the area; Its better, but the focus color and the selection are not displayed correctly. Maybe someone has an idea, what to do about that.

Link to comment
Share on other sites

  • 1 year later...

Hello @Kanashius

Thank you for your effort.

I need to only edit the third column. So, I used your example and made the below change. I'm still able edit column zero. Thoughts?
 

;__ListViewEditInput_ListViewAdd($hGui, $iListView, "0,1,2")
__ListViewEditInput_ListViewAdd($hGui, $iListView, "2")

 

Edited by Saad
Link to comment
Share on other sites

I think I found the issue/resolution.

In the Return line, surround $iSubIndex with a String function. Also, surround $iIndex with a String function as well.

After the change, row 0 and col 0 are not editable unless included in the list.

Func __ListViewEditInput_isCellEditable($hListview, $iIndex, $iSubIndex)
    If Not IsHWnd($hListView) Then $hListView = GUICtrlGetHandle($hListView)
    If MapExists($__ListViewEditInput_arListViews, $hListview) Then
        Local $pListViewData = $__ListViewEditInput_arListViews[$hListview]
        Return ($pListViewData.allCols Or _ArraySearch(StringSplit($pListViewData.cols, ",", 1+2), String($iSubIndex))>=0) And _
               ($pListViewData.allRows Or _ArraySearch(StringSplit($pListViewData.rows, ",", 1+2), String($iIndex))>=0)
    EndIf
    return False
EndFunc

 

Link to comment
Share on other sites

  • 5 months later...

Hello,

I'm trying to use your UDF but it's not working as expected. For example, to prevent edit column 1 from being edited, I changed your example from "0,1,2" to "1,2" and I'm still able edit column 0. Also, as @Saad said, allowing editing only one column ("1" or "2" in your example) also not work as expected. Can you please explain how to do it in right way 

I'm trying to use your UDF but it's not working as expected. For example, to prevent column 0 from being edited, I changed your example from "0,1,2" to "1,2" and I can still edit column 0. Also, as @Saad said, editing only one column (change "1" or "2" in your example) also do not work properly.

Can you please explain how to do this correctly?

Link to comment
Share on other sites

Hi :)
I did the complete rework using maps instead of dllstructs. This enables me to use them, to save the rows/cols in a map and check, if an index is in there.

This is faster and also fixes your problem, because the string is not parsed anymore.
A nice bonus: I use regexp for parsing them now, so its not limited to , seperated lists anymore. It simply parses all connected numbers as an index, with non number characters inbetween => "1,2,3" / "1 2 3" / "1.2.3" / ...

TLDR: Bug fixed 😄
You find the new version in the post at the top.

Link to comment
Share on other sites

Fixed that bug.

For some reason, the

_WinAPI_RegisterHotKey($hGui, BitOR(0x0100,$VK_ESCAPE), 0, $VK_ESCAPE)

Registeres the key globaly, not just for the $hGui, like I assumed. Not sure, if that is intended or a Bug.
The _WinProc then reports always with the $hGui, even if the Key was send with a different Gui active...

I avoided that thing entirely and use a global keyboard hook and filter for the active window now.

Link to comment
Share on other sites

Now it works great for me. 
There is still a "minor" bug that doesn't bother me in my current project - now hooked keys not work inside the GUI. Probably necessary check if the LV is in focus and release if not.

Thanks for sharing super easy to use UDF. I like it!

Link to comment
Share on other sites

Oh, yeah, I totally overlooked that, was a bit in a hurry 😅

But as compensation:
I found out, what to do to select the item again, after editing and added that to the next cell editing as well :)
Use _GUICtrlListView_SetItemSelected to set the selected item (not so new), but _GUICtrlListView_ClickItem after that brings the listview into focus again (GuiControlSetState(..., $GUI_FOCUS) did not do that for whatever reason...)

Edited by Kanashius
Link to comment
Share on other sites

Hi. 

Just tried last 3.0.2 version. 

1. After clicking 4:2 cell on the right LV and then Escape or click once on some row on the left LV - focus goes to 4:0 cell and then your example crashes

2. After once clicking on some row on the left LV and then on the right LV - the left LV always in focus 

 

Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
 Share

×
×
  • Create New...