Is a global variable that is written by a foreground app available to the background process? And vice-versa: is a global variable written from the background available to the foreground? Subject to synchronization? Where could I read things like this about foreground vs. background processes and their interaction / communication?
I assume there is a process, "P0", which executes the Button1.Click event, correct? Is it fg or bg? When does it terminate? It would seem to continue, with screen1 being "active" and visible.
Does the Button1.Click event create (via itto1.CreateProcess) a background or foreground process, call it "P1", which then executes procedure "clock"?
Does "P1" run to completion after registering the Clock1.Timer event?
What/which process executes the "timer" procedure when the Clock1.Timer event fires?
I think I will stop there for now.
I should add that this is not just of academic interest. I am aware that some things cannot be done from a background process (or an inactive process - what's the difference. Oops, there's another question:-) . For example, I find that a Notify1.ShowAlert will work from places where a toast ( [Free Open Source] my toast extension 3.0 ) does not - or perhaps there are other problems with my tests that lead me to conclude this.
Also regarding the Notifier1.ShowAlert, they are UI interactions that do not always work on across all devices, so I wouldnt recommend touching them in Itoo.
Well, clearly, this is not something I am going to understand ... so I may as well "believe in magic"
So now, I must let you see my app and get some help.
I want to alert the user with something like a toast or Notifier1.ShowAlert when cell data has been left on and/or is actually being used (under some circumstances, configurable by the user).
The toast I am using does not work from the background timer event processing (I figured there is a reason for this that has to do with bg/fg), but Notifier1.ShowAlert seems to be working, so I was counting on using it. Then I am advised:
So, am I going to have to give up on displaying a brief message on top of the active app and just use a notification to alert the user?
-Randal
So far I have only tested this on android 8.0, but I would like it to work up through 14.
Hi, if the Notifier1.ShowAlert works for you, then you may use it, but it may be inconsistent across devices. You may alternatively show a notification to the user instead:
Thanks for the clarification. I will plan to use both ShowAlert and a notification.
I have already imported the modified Notification Style (see in my blocks the calls to Has/Ask permission blocks)
Thanks again for the interaction/help.
Kind regards,
Randal
[20240125 edit]
I tried the DataMinder_toastCase test app on a Pixel running Android 12 and the toast worked! but the Notifier1.ShowAlert did not So, I think I will start out with all three mechanisms, emphasize the NotificationStyle notification, but also include the ShowAlert and toast. I can allow the user to select the methods which work on his device and disable the others.
I have just tracked down one of my programming errors which turned out to be the use of a built in Color component block where a hexadecimal number for a color was expected in a block that was being executed by an the event registered by:
This error of mine became obvious when I executed the same (or similar) block from the foreground portion of the app - it was clearly reported by the system when it occurred.
My question is: Is it possible to gain insight into such errors when executed in the background?
Could the Screen1.ErrorOccurred event be made to fire? Possibly by registering it with itoo1.RegisterEvent?
How about the error log? Could anything be written to the error log and viewed by "adb.exe logcat"?
Is there some way to connect (AI Companion, Emulator, USB) and debug such an app? My app foreground process closes immediately after it creates the background task. If I kept it running would background errors such as this be reported to the UI?
I'll possibly work on a better feature to report errors, (after two months, my exams get over).
The only way to debug right now is to check the logcat.
Itoo does not support companion debugging, even if it is someway implemented to mimic the functionality, we cannot afford its code maintainability.
So there is some kind of error happening... Did you try to use ADB to check for the error logcat? If you are able to capture it through ADB, you can send it personally to me. Most of the times errors happen when components are not initialzed or set properly...
Thank you for addressing my general and specific question.
That would seem to be a very useful enhancement. After a while, since users could see their own errors displayed, you might recover your time spent developing the capability because you would get fewer questions about problems we might be having
Yes, I did. But I never was able to locate anything in the log. If you think it should have been there, then I can re-run the buggy version and try again.
Do you have any suggestions as to "adb.exe logcat" options that might eliminate entries that would not be of interest? perhaps piping to "grep XXXX".
As I mentioned, I found the error after I ran the same type buggy blocks (I had used a color when a hex number for a color was required.) in a foreground portion of the app - the error was reported to the phone screen.
I will see if I can build a small test case that exemplifies the error and then see if I can locate the error using logcat. This would be good practice for locating future bugs.
Great extension with it any application made with app inventor can work in the background.
I see that there is doubt about how the extension works, I am attaching two aia files, which can help you understand how it works.
One is a step counting app that works in the background, so it will always count your steps.
Another is an Alarm manager
Both work correctly, although as usually happens, the battery mode must be set to "No restrictions" for them to work correctly on lame Xiaomi or Samsung phones.
two requests to the developer
First, the notification can be interacted within the service to change the title and subtitle and when you click on it, the activity opens with the NEW_TASK flag.
Another option is to create a kind of static procedure in the main activity that can be used in the service, so that the number of blocks can be removed from it.
WOW I LOVE IT!!! That's incredible what you have done with Itoo, especially the Pedometer one, can you please publish them as a guide (a new topic) so that it could help others?
Can you tell us where does the block "IbpAllAlarms.HexToColor" come from? Also you are passing a color to a block when it expects hexadecimal value (something like #845EC2)... So the error is obvious...