-
-
Notifications
You must be signed in to change notification settings - Fork 529
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
Hot restart - camera no longer usable #1037
Comments
Here too, I need to reinstall the app. If I close and open it again, the same error persists. mobile_scanner: ^5.0.0 |
@dcarv01 can you tell me your device + os, that's weird to uninstall as a unique solution. |
same #773 (comment) |
Personally I didn't have an issue with the hot reload, only the hot restart. |
@EArminjon We indeed need to provide better support for hot reload. I filed #773 for that in the past. We might be able to use the reassemble hook from the framework, but I'm not sure. I'm going to close this issue in favor of #773 so that we have only one tracking issue. |
Hello @navaronbracke, I didn't talk about hot reload but hot restart, can you confirm that your answer fit for hot restart ? |
Hot restart is a full restart of the app state. Perhaps if we fix hot reload, we might also fix it for hot restart? |
Personally i didn't have any issue around hot reload, only hot restart for both Android and iOS. |
To be more precise : on hot restart camera work but not the preview on flutter side (black screen) : i can scan some document despite my black screen. |
I too have problem only with Hot restart, hot reload is ok.
I tried again, and there was no need to uninstall, perhaps I was mistaken. |
A hint : I've removed some protections to force call the stop() method from MobileScanner.swift before instantiate the MobileScannerController() on my dart side. Result : On hot restart camera works. Limit : I can see the green camera OS icon after the hot restart, so camera is still used by something. Not normal. Conclusion : We need to find a way on hot restart to remove used resources or on start() to do so. (maybe this topic can help once fixed : flutter/flutter#10437) |
On our app, we always dispose the MobileScannerController when we need to do 'pause' or to open a new page which potentially will contain an other MobileScannerController(). We use visibility detector to start() the camera and we delay it a bit to let other MobileScannerController() instance the time to dispose. That's an other issue which i will open later because it can be fixed maybe by this issue. |
Based on these observations and as it's not hot reload directly linked, I think we can reopen :/ ? |
I will keep this issue open for tracking. Perhaps if we fix the hot reload support, the other issue goes away, although I am not certain. |
@EArminjon I just now published a fix on the master channel that addresses the problems with hot reload in #1086 I plan on releasing a fix with this patch shortly. Could you verify on master (using a git override) if this issue is also fixed by that patch? I specifically targeted hot reload and not hot restart, hence the question. |
Hello @navaronbracke, still black on hot restart :'( ! mobile_scanner:
git:
url: https://github.com/juliansteenbakker/mobile_scanner
|
Interesting. Does hot reload work for you? (using lowercase In the case of hot restart (upper case |
Hot reload always worked for me. Today i use on my project Actually no error despite the black screen. When i put some breakpoints on your package i saw "MobileScannerErrorCode.controllerAlreadyInitialized" (see code after). Maybe the previous instance can't kill the camera and so after app restart it can't create an other one. if (error.errorCode ==
MobileScannerErrorCode.controllerAlreadyInitialized) {
return;
} |
Hmm, yes this seems like an issue with I added the check on I think you might be right that in this case, we should still do the above check, but we should actually stop the old controller and then just continue. So we have two situations: Hot Reload (r): The Dart snapshot is reloaded, but the app still runs. In this case, prevent the controller from starting again, using the check above, as the native code has not changed and the app is still running. Only the Dart snapshot has changed in memory. This is what the patch that I finished today does. To fix the second case, we will probably need to know if the app restarted due to hot reload or hot restart. When I implemented the check above I wasn't sure if we should "ignore the additional calls to start and abort" or "detect it, dispose of the old instance and continue with starting a new instance" So I think I made the wrong choice here? Although, now that we have the new check in place, adjusting it to fit the new situation should be easy (in the if statement, we What do you think about this option? |
Sorry, for the delay. The following code didn't fix the issue (even if i dispose my page and recreate it, camera is not longer available), it's more deep. if (error.errorCode ==
MobileScannerErrorCode.controllerAlreadyInitialized) {
await stop();
return;
} As i remember, Flutter didn't allow package to detect Hot Restart (only Hot Reload) : flutter/flutter#10437. I don't know so if it's possible to today to find a way for disposing the camera instance on hot restart. |
Shouldn't we do do this instead? (in
But if this also does not fix the issue, then I agree that this can only be fixed when flutter/flutter#10437 is fixed, so that we can detect this case in the plugin, using an API. |
I've tested that, it sadly didn't work. |
If i do a hot restart while camera is displayed, I no longer have the possibility to use it until app is closed.
mobile_scanner: ^5.0.1
The text was updated successfully, but these errors were encountered: