zixpo / candybar

Dashboard for Android Icon Packs. Supported by the community.
Apache License 2.0
288 stars 53 forks source link

Can't apply icon manually in nova through icon pack #185

Open MiepHD opened 4 months ago

MiepHD commented 4 months ago

Hello, In Nova Launcher you can choose an icon manually through the ui of nova but if you choose from the app after selecting an icon the icon won't apply. The following error might be connected to that. As this problem doesn't occur on other apps like acticons or delta I probably have to change something but I have no idea what the issue could be.

Icon Pack Name : cuscon
Manufacturer : samsung
Model : SM-N980F
Product : c1sxx
Screen Resolution : 1080 x 2173 pixels
Android Version : 13
App Version : 4.0.1.6
CandyBar Version : 3.18.6
Crash Time : 2024-03-06 18:23:51
Class Name : java.lang.RuntimeException
Caused By : java.lang.RuntimeException: android.os.TransactionTooLargeException: data parcel size 1048972 bytes

android.app.ActivityClient.finishActivity(ActivityClient.java:167)
android.app.Activity.finish(Activity.java:6845)
android.app.Activity.finish(Activity.java:6862)
android.app.Activity.finishAfterTransition(Activity.java:6915)
android.app.Activity.navigateBack(Activity.java:4092)
android.app.Activity.onBackPressed(Activity.java:4086)
androidx.activity.ComponentActivity.v(Unknown Source:0)
androidx.activity.ComponentActivity$a.run(SourceFile:3)
androidx.activity.OnBackPressedDispatcher.c(SourceFile:33)
androidx.activity.ComponentActivity.onBackPressed(Unknown Source:2)
o.qb.onBackPressed(SourceFile:49)
android.app.Activity.onKeyUp(Activity.java:3995)
android.view.KeyEvent.dispatch(KeyEvent.java:3532)
android.app.Activity.dispatchKeyEvent(Activity.java:4347)
o.ef.o(Unknown Source:0)
o.q30.e(SourceFile:11)
o.ef.dispatchKeyEvent(SourceFile:19)
o.r2.dispatchKeyEvent(SourceFile:23)
o.f71.dispatchKeyEvent(Unknown Source:2)
o.a3$n.dispatchKeyEvent(SourceFile:22)
com.android.internal.policy.DecorView.dispatchKeyEvent(DecorView.java:928)
android.view.ViewRootImpl$ViewPostImeInputStage.processKeyEvent(ViewRootImpl.java:8056)
android.view.ViewRootImpl$ViewPostImeInputStage.onProcess(ViewRootImpl.java:7864)
android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:7213)
android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:7270)
android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:7236)
android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:7434)
android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:7244)
android.view.ViewRootImpl$AsyncInputStage.apply(ViewRootImpl.java:7491)
android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:7217)
android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:7270)
android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:7236)
android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:7244)
android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:7217)
android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:7270)
android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:7236)
android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:7467)
android.view.ViewRootImpl$ImeInputStage.onFinishedInputEvent(ViewRootImpl.java:7676)
android.view.inputmethod.InputMethodManager$PendingEvent.run(InputMethodManager.java:3897)
android.view.inputmethod.InputMethodManager.invokeFinishedInputEventCallback(InputMethodManager.java:3414)
android.view.inputmethod.InputMethodManager.finishedInputEvent(InputMethodManager.java:3405)
android.view.inputmethod.InputMethodManager$ImeInputEventSender.onInputEventFinished(InputMethodManager.java:3874)
android.view.InputEventSender.dispatchInputEventFinished(InputEventSender.java:154)
android.os.MessageQueue.nativePollOnce(Native Method)
android.os.MessageQueue.next(MessageQueue.java:335)
android.os.Looper.loopOnce(Looper.java:186)
android.os.Looper.loop(Looper.java:313)
android.app.ActivityThread.main(ActivityThread.java:8762)
java.lang.reflect.Method.invoke(Native Method)
com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:604)
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1067)
topcaser commented 3 months ago

This is an annoying error. Can't anyone help?

moertel commented 2 months ago

This is an annoying error. Can't anyone help?

It's super difficult to debug something like this, especially as other icon packs work fine and it's not reproducible in CandyBar itself.

If I were to make a guess, I'd say that the exception message saying something about a "transaction size too large", perhaps the icon file is too big. This would explain why it's an isolated issue with a particular icon pack, rather than a general bug.

MiepHD commented 2 months ago

The icons of my icon pack are all lower than 71kb

moertel commented 2 months ago

71kB per icon? If so, that's quite huge. I don't know where the limits are but as a ballpark number, my icons are 200x200px PNGs and only 1kB each.

MiepHD commented 2 months ago

I'll try reducing the image size and see if that helped. Then I'll tell if that fixes the issue

Donnnno commented 1 month ago

Works for me with cuscon. I think this can be closed?

MiepHD commented 1 month ago

For me it still won't work. Have you used the external icon chooser where it opens the app? (When you use the selection in nova it works)