03-19-2025 07:11 AM
Trying to use Windows GDI functions to draw a simple shape on the screen, as my application does in many other functions. This time I'm seeing an inexplicable memory error. See the attached code.
03-20-2025 10:50 AM
I've never used the windoze drawing tools, but I have encountered stuff like what you are seeing occasionally.
It may seem silly, but I'd try rearranging the order in which you perform some of your operations... as simple as declaring the variables in a different order, and setting up your points array values before you set up the pen. It could be that your oldPen variable is declared based on an older return data size, and you've got a newer .dll that returns a larger amount of data from the SelectObject function than expected... and subsequently overwrites some of your point array. Try switching the order up and see if you see any difference in where the memory is getting corrupted.
03-23-2025 08:21 AM
There's also the option that the C compiler is actually messing up the stack somehow. I've seen reports before where CVI seemed to have trouble with arrays declared on the stack and not quite reserving the right amount of stack space for it. You might try to use a dynamically allocated array and afterwards deallocate it. Yes it's not nice and feels rather awkward in terms of simplicity and performance, but sometimes you have to row with the paddles you have, rather than hoping to get better ones.
Also interesting would be to know the CVI version. My memory, which never has been faultless, seems to say that this was an issue with CVI 2017 or maybe 2019, but I'm not sure.
03-25-2025 09:37 AM
It's version 2013.
03-28-2025 05:30 AM
What are your possibilities to try with a newer version? The problem definitely sounds remotely familiar and it was related to certain CVI versions. But my memory isn't anymore what it never was to start with, so which specific version this was occuring with is shrouded in mystery.