- 
                Posts363
- 
                Joined
- 
                Last visited
- 
                Days Won37
Content Type
Profiles
Forums
Downloads
Gallery
Everything posted by dadreamer
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General Looks pretty much like it should. 🙂
- 
	  Problem to interface DLL with the new DPC++ intel compilerdadreamer replied to Youssef Menjour's topic in LabVIEW General Maybe the reason is that LabVIEW cannot find some DPC++ Runtime library during the DLL load process (sycl.dll for instance or another one). Could you check with Dependency Walker, which libraries are in dependencies of your DLL?
- 
	  Problem to interface DLL with the new DPC++ intel compilerdadreamer replied to Youssef Menjour's topic in LabVIEW General Just switch to Release option on the MSVS toolbar. As to the differences, you may read about them e.g. here . To add to there, debug builds depend on the debug version of Visual Studio Runtime libraries, whereas release builds depend on common MSVCRT DLLs, that are very likely already installed in the system. Hence if you compile debug app or library and deploy it to machines without Visual Studio installed, it will ask you for the debug DLLs or even the whole Visual Studio to be installed. Release app/DLL on the other hand usually requires Visual C++ Redistributable Runtime only.
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General For "stop" frame: place Stop.vi between the CLFN and Unregister node. And as you are creating the event before the loop (Create User Event node), you should destroy it also after the loop.
- 
	  Problem to interface DLL with the new DPC++ intel compilerdadreamer replied to Youssef Menjour's topic in LabVIEW General For MSVS - on the left of the function name, for LabVIEW - in the CLFN settings. extern "C" __declspec(dllexport) int __stdcall Mult(int a) { // will be exported with stdcall convention }
- 
	  Problem to interface DLL with the new DPC++ intel compilerdadreamer replied to Youssef Menjour's topic in LabVIEW General Did you try Release build also? I noticed, that you're exporting Mult function without explicit specification of the calling convention. By default Visual Studio exports in cdecl convention. But in LabVIEW you set stdcall convention. Likely it's not the reason for errors though.
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General Seems more or less ok. But better to place UninstallCallback CLFN in the "stop" frame as you install the callback in the "start" frame. I also assume you're passing NotARefnum as Adapt to Type -> Handles by Values with cdecl convention. Wait, I've just thought it would be good to have an organized dataflow in both "start" and "stop" frames. In "start" first do the event handling (registration etc.), then call Start.vi, then install the callback. In "stop" do in the opposite order. You may easily set the dataflow order with two ways: either with brown error wire or with Sequence Structure. There's a State Machine pattern as well, but I feel you're not ready to remake all the program right now.
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General No! You have to change this line: { return installFunc(lRealHandle, DataCallBack, (DWORD)(*refnum)); } to these lines: { if (refnum && *refnum) return installFunc(lRealHandle, DataCallBack, (DWORD)(*refnum)); else return installFunc(lRealHandle, NULL, 0)); } And that's all! Do not touch anything else in the code. Rebuild the DLL then.
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General @alvise Leaving the lyrics behind, so you got the DLL compiled along with the changes proposed by Rolf? If yes, have you made UninstallCallback VI based on InstallCallback VI with minor changes, proposed by Rolf? If yes, did you put that new VI inside your program and run the test playback again?
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General Why not? 🥴
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General These modifications were made as well? extern "C" __declspec(dllexport) BOOL __cdecl InstallStandardCallback(LONG lRealHandle, LVUserEventRef * refnum) { HMODULE hDLL = LoadLibraryW(L"HCNetSDK.dll"); if (hDLL) { Type_SetStandardDataCallBack installFunc = (Type_SetStandardDataCallBack)GetProcAddress(hDLL, "NET_DVR_SetStandardDataCallBack"); if (installFunc) { if (refnum && *refnum) return installFunc(lRealHandle, DataCallBack, (DWORD)(*refnum)); else return installFunc(lRealHandle, NULL, 0)); } FreeLibrary(hDLL); } return FALSE; }
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General You still did not apply UninstallCallback to your VI. This may help or may not. I can't say now, what's the reason behind your problem. When you will be ready to test with UninstallCallback, restart LabVIEW completely to begin with fresh resources. And as you already are getting stream's binary data, save a single NET_DVR_SYSHEAD (1) packet and a single NET_DVR_STREAMDATA (2) packet to two separate binary files, so we could get a chance to look at the format. Use a Case Structure to differentiate them. Save one packet only, if possible, not two going one after the other. Post them afterwards.
- 
	  Download link for OpenG library compatible with LabVIEW 7.1dadreamer replied to KumarB's topic in OpenG General Discussions I assume you may easily find all these packages on SourceForge, e.g. this is a page for oglib_error-2.0-1: https://sourceforge.net/projects/opengtoolkit/files/lib_error/2.0/
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General 
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General @alvise I also recommend putting a CLFN with SetCbState call and wire a False constant to it after the While loop, so it would deny posting anyways.
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General Could it be that the callback doesn't get installed? Did you try to uninstall it after the loop ends?
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General If I got it right, he says that on one run of the VI the events are being sent OK, but on another run (after he stops the VI and runs it again) no events is sent regardless of the button being pressed.
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General Is your cluster elements order correct? Open Context Help window, then select Wiring Tool and hover it over the pink wire. In the Context Help you'll see order of the cluster elements.
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General @alvise Do you really need audio in your streams? Because if no, then it would be a way easier to work with pure NET_DVR_STD_VIDEODATA (4) packets.
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General Yes. Make handle as U8 array instead of a numeric.
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General Now correct the cluster contents as proposed and test again.
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General This explains why he was seeing unstable behaviour from run to run. This is what happens, when two advisers are trying to help simultaneously. 😃 I often prefer a slightly different way to transfer data from the callback. I post a pointer to data and in LabVIEW I read it out with MoveBlock (because I like to see a minimalistic external code and do most of the coding in LV instead). By the way, I kind of think posting an U32/U64 number might work, if DSDisposeHandle would be moved to the LV Event frame from the callback code and in that frame MoveBlock + DSDisposeHandle would be called.
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General Because you exported it. Leave it as is. Take a boolean button with Switch when released mechanical action and create a new event frame "Value Change" with that button inside. Put a CLFN with SetCbState call, add one parameter in its settings with Adapt to Type -> Handles by Values data type and format. Wire your button to the CLFN. Now you're controlling the callback event flow.
- 
	  Using the DLL files of an application compiled with C# with labviewdadreamer replied to alvise's topic in LabVIEW General Rolf nailed it already 🙂 So do as written above.

 
         
					
						 
					
						 
                    