Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

OBS Freezing Constantly #33

Open
guiglass opened this issue Mar 5, 2023 · 10 comments
Open

OBS Freezing Constantly #33

guiglass opened this issue Mar 5, 2023 · 10 comments

Comments

@guiglass
Copy link

guiglass commented Mar 5, 2023

Hi, after activating DirectShow then starting OBS when I click add Video Capture Device the OBS application freezes. This never used to happen so I think it's OBS related but maybe it's DirectShow or something else. Anyway can someone help me understand why it's no longer possible to use UnityCapture with OBS??

@Radium-bit
Copy link

Hi, after activating DirectShow then starting OBS when I click add Video Capture Device the OBS application freezes. This never used to happen so I think it's OBS related but maybe it's DirectShow or something else. Anyway can someone help me understand why it's no longer possible to use UnityCapture with OBS??

It has been solved, in my updated Fork Radium-bit/UnityCapture

@guiglass
Copy link
Author

guiglass commented Mar 11, 2023

This sounds great, I did test the patch and it works. Unfortunitely OBS plans to block the UnityCapture .dlls

So I think that fork will no longer work in OBS after the next update. They recommend to hack the .dll names or whatever. So maybe it would be wise to fix the .dll in your fork so they are not blacklisted by OBS?

@schellingb
Copy link
Owner

Uhh, I'm rarely able to help out here anymore because nowadays I'm so removed from any Unity development so I can't even test UnityCapture anymore.
But if there's some code people are confident I should merge or me just rebuilding this project and putting up a new release without being able to test it myself I think I can do that. Sorry about being so disconnected but maybe we can avoid getting blocked or getting unblocked in the future...

@nickleijenhorst
Copy link

Hi, after activating DirectShow then starting OBS when I click add Video Capture Device the OBS application freezes. This never used to happen so I think it's OBS related but maybe it's DirectShow or something else. Anyway can someone help me understand why it's no longer possible to use UnityCapture with OBS??

It has been solved, in my updated Fork Radium-bit/UnityCapture

Thank you so much man. Can I ask out of interest what change you had to make to prevent OBS from crashing?

@Radium-bit
Copy link

Hi, after activating DirectShow then starting OBS when I click add Video Capture Device the OBS application freezes. This never used to happen so I think it's OBS related but maybe it's DirectShow or something else. Anyway can someone help me understand why it's no longer possible to use UnityCapture with OBS??

It has been solved, in my updated Fork Radium-bit/UnityCapture

Thank you so much man. Can I ask out of interest what change you had to make to prevent OBS from crashing?

Sorry, I am not engaged in the development of UnityCapture, sorry for not being able to help you too much

@Fenrirthviti
Copy link

This sounds great, I did test the patch and it works. Unfortunitely OBS plans to block the UnityCapture .dlls

So I think that fork will no longer work in OBS after the next update. They recommend to hack the .dll names or whatever. So maybe it would be wise to fix the .dll in your fork so they are not blacklisted by OBS?

Hi, OBS here. Just want to clarify, we don't consider a rename a "hack". The issue is that without a name change, a .dll file could, or could not, have the fix. There's no way to tell, and since anyone can build a new file without the fix at any time, we can't even use "after X date" as a filter. Since the majority of the files with that name out there do not have the fix, we are opting to block it, because the alternative is leaving users with effectively a crash condition. Files that have had their name changed are more likely to contain the fix, and changing the filename is trivial. We understand that it's possible to have a file with the same name, that does have the fix, but we have no way of validating or confirming that, so we're taking the safe route of recommending that people also change the name.

To summarize, we simply recommend that any forks that want to avoid the .dll block in OBS also change the name of the generated .dll file, and from our observation, most already have. That's all.

@schellingb
Copy link
Owner

@Fenrirthviti Thank you for posting here. I think OBS's action is fair. As the author of this project I would like to better resolve this though. I'm still not 100% sure but I think a218037 is what I need to incorporate, then I can change the DLL names and make a new release. I will try to get around to do that when I have a free evening. Hopefully this is correct and won't cause more trouble :-)

@Fenrirthviti
Copy link

There's a few different approaches to the same fix floating around, let me check internally and see if there was any strong opinion on the "best" fix, and I will get back to you.

@Fenrirthviti
Copy link

Confirmed that the correct fix is already merged: 2eabf0f

All that needs to be done is new release + rename, and things should be good to go here.

schellingb added a commit that referenced this issue Apr 14, 2023
Capture filter DLLs renamed from "UnityCaptureFilter32bit.dll" and "UnityCaptureFilter64bit.dll" to "UnityCaptureFilter32.dll" and "UnityCaptureFilter64.dll". This new release which includes 2eabf0f should not cause deadlocks when used in software like OBS anymore. A new DLL name is used because the old names are now in a block list in OBS due to the faulty behavior of the old version.
@schellingb
Copy link
Owner

We did it everyone! Thank you very much to @Fenrirthviti for confirming the fix!!
Sorry for the slow response and thanks for the patience to everyone here and in #30.
If someone can confirm the new DLLs (now named without the "bit" suffix) work fine in OBS I'd be very grateful.
Cheers!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants