-
-
Notifications
You must be signed in to change notification settings - Fork 362
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
location pointer pin crashes on Xiaomi Redmi Note3 (60.0-alpha2) #6001
Comments
That phone does not have screen recorder, so had to use another phone to record it... small_20241104_180827_SC_crashes.mp4and here is SCEE on the same area with about same amount of data loaded, working just fine: small_20241104_180332_SCEE_works.mp4I switched between several times, and always SC 6.0-alpha2 crashed, and SCEE 59.1 worked. |
Don't know if it helps, but I've tried looking up that error - there were not much matches, but those that I found always seemed (e.g. android/sunflower#519 or material-components/material-components-android#661) related to some "0dp" fix MaterialComponents thingies like solved here: https://stackoverflow.com/questions/36115934/android-opengl-error-during-camera-animation |
Uff, a crash in native code, so we can not really fix this here, only try to avoid it occuring, i.e. working around it. Are you able to post the stack trace here? |
Yeah, but since it doesn't crash in SCEE 59.1, I'd guess SC 59.1 was also fine, so it should be possible to isolate and then change the factor leading up to the crashes. Do you want me to some more tests on that device?
Here it is:
|
Thanks! Hmm... not helpful, though. So the crash does not happen when location is off? At the moment I have no idea what could cause this. If your view is not glued to the location, the following things should be different as compared to having no location at all:
Since you are currently the only one who can reproduce this, I fear you are currently the only one who can dig down deeper what exactly is causing the crash. So, you could comment out some stuff that is happening when the app has location and run the app again to see if the crash is still reproducible then. |
as suggested in streetcomplete#6001 (comment)
The debug effort so far:
log
Git bisect log: 6001-bisectlog1.txt I will try digging some more, and try to comment out some things (if I can figure out which ones) ... If anybody has any more hints on what to try, let me know. |
👍 You could add a log to Also, what changed is the version of compose. Maybe compose has a bug. You could try to downgrade Compose to see if the issue also appears for an older version of compose. |
I've tried reverting to previous compose versions used in working 59.3, but it did not help. It seems it crashes even if it never got data from the Internet, and that it crashes only when current location pointer gets off the screen. Below are the detailed steps, logs, and video. Any hint what to try next?
Here is the log and the video: small_Screenlog_crash_left_20241120_1930.mp4 |
Okay, we are getting closer. In MainScreen, in line 372 or so, the PointerPinButton is added. What I find interesting, is that in your video, the display of that button flickers. What is happening here? Is the calculated intersection alternating between null and a proper value? You could log that to see what the values are. Also, if the crash never happens when it is at the top of the screen, maybe it has something to do with positioning the pointer pin button? You could replace the Modifier with |
BTW, I've noticed following in the log, which seems related to StreetComplete debug build:
Is that perhaps interesting?
I've addeded that debug and it displays the following when pointers go up and flickers: The values in the log look normal to me:
however, it seems that it flickers because on some movements it doesn't get drawn, even if values look normal, e.g. here:
Values leading to the crash also look normal if I pan the screen so icon goes off on the left edge of the screen:
|
Yes. In fact, with that change, it now crashes even if it goes to the top of the screen:
|
No.
Okay, interesting. So, the calculation is fine, and the calculation isn't "flickering". But for some reason, it's not drawn every second-or-so UI update. That'd be an issue on its own, but maybe it is connected.
What do you mean? It shouldn't go to the top of the screen but be in the center of the screen always. |
Yeah, that extra pointer which points towards the current location (blue dot in white teardrop) is indeed pinned in the center of the screen instead pinned to one of the borders (as it was before), but when the original location icon (blue circle with direction-view-cone) goes on the top of the screen, it crashes (while location icon going up was only survivable direction before this centering-change) Here is a video, perhaps it will be clearer: small_Screenrecorder-2024-11-23-23-07-08-628.mp4 |
Weird, how can it crash now when less things are done? (I.e. no positioning is done) Regarding the flickering, you put the log at the position where |
I have no idea 🤷♂️ However, when I remove log_SC_removed_PointerPinButton-6915963.txt small_ScreenRecording_SC_removed_PointerPinButton-6915963.mp4Any other ideas what I could try?
I'm totally out of my depth here (as I don't even understand how those things get called and by who) so can't even say if your question is rhetorical question or am I supposed to try something here to provide the answer, sorry. 😅 I'm willing to try any idea you have and test and provide output, but I have no idea how/where to add debug points... |
I've managed to find another datapoint: it doesn't crash if I leave |
Ok, this is getting more and more bizzare. I've done three tests, all the same with
|
Okay, let's try two things. First, revert to the current master state, then add
just before
(you need to add The log output, does it log "null" often/sometimes? Or always an angle plus position?
|
Do you have Android Studio installed?
|
as suggested in 3. streetcomplete#6001 (comment)
as suggested in 4. streetcomplete#6001 (comment)
OK, done in mnalis@c77c47c. It seems to display "null" very often, but it seems to me only while my location is still inside of the screen. When I get out of the screen so teardrop-pin is created, it seems to only contain positive values until it crashes, e.g. example log
Depends on the constant, see #6001 (comment) for examples. Yes, with
No.
Yes, (mnalis@d988393) solves the crash (the pin is displayed as blue circle in white box)
Yes, (mnalis@2500c76) also solves the crash (the pin looks normal blue dot in white teardrop and even seems to rotate correctly, but it is always placed at top-left corner no matter which side of the screen I moved the GPS dot out) |
What, either of 3 and 4 solves the crash? Are you sure? |
Yes, either of those changes avoids the crash. Here is video of only change 3 (mnalis@d988393): small_SC_only_change_3_git_d988393.mp4And here is video of only change 4 (mnalis@2500c76): small_SC_only_change_4_git_2500c76.mp4 |
Looking at the code and searching the net, I've found a workaround; forcing mnalis@b24230f#diff-d8525b7358f4e0685bcc6c4d663ea4fa11fcd9abfe8f849b0aa28239bea47860L70 Doing that fixes the crash, at only the cost of not displaying slight shadow on that teardrop pin. It seems to be an known issue in some Android versions, see https://stackoverflow.com/a/37249265/2600099 So, shadow can be disabled always there, or only when problematic Android version is detected, like e.g. here: material-components/material-components-android@3c3ac61 Would you like me to make a PR @westnordost, and if so, which solution would you prefer? |
Alright, I'll try that, thank you for your relentless testing! |
Alright, I'll try that, thank you for your relentless testing! Do you have an Android 7 device with which you can reproduce the issue? Otherwise, I will jsut add the exception for Android 6 |
Unfortunately not, only Android 7.1 device I have does not support GLES 3.0 so it doesn't really display anything in recent SC versions (#6029)... I've tried moving screen around blindly on that device and it didn't seem to crash, but that is more likely because MapLibre doesn't work at all there (as other things looks fishy too), then a confirmation the bug doesn't exist in Android 7... 🤷♂️ Next device up which I have is Android 9, and that does not have the bug... |
While trying to help debug performance issues in #5994 (comment), I've encountered almost immediate crashes with this phone.
I thought of #5954 / maplibre/maplibre-native#2206, but:
Abort message: Error: Spot pair overlow!!! used 205, total 116
)How to Reproduce
Expected Behavior
I'd expect it to not crash. Also of note:
Versions affected
60.0-alpha2, Android 6.0.1 on Xiaomi Redmi Note 3
The text was updated successfully, but these errors were encountered: