processing4
processing4 copied to clipboard
Improve PApplet draw method's documentation or behavior
Description
A subclass of PApplet that overrides draw and invokes super.draw (which could happen inadvertently if using an IDE such as IntelliJ that auto-completes overridden methods) will not respond to user events (e.g. mouse clicks). Currently, this is a tricky bug to fix unless a developer is savvy enough to hunt down this GitHub repository and read the implementation of the PApplet draw method. There is a print statement in the implementation that might provide a clue, but it's currently commented out. Uncommenting and providing more details in that print statement would be helpful. For example, you could advise the developer to reconsider invoking super.draw, and explain that it will suspend event handling. (That said, perhaps a better solution would be for the PApplet draw method not to assume that it's being invoked because the subclass has not overridden draw.)
Expected Behavior
public void draw() { // if no draw method, then shut things down System.out.println("You're either not overriding the draw method or invoking super.draw from your draw method."); System.out.println("If the latter, are you sure you mean to do this? Invoking super.draw will suspend event handling."); finished = true; }
Current Behavior
public void draw() { // if no draw method, then shut things down //System.out.println("no draw method, goodbye"); finished = true; }
Steps to Reproduce
- Subclass PApplet.
- Override the draw method in the subclass.
- Invoke super.draw from the new draw method.
Your Environment
- Processing version: 4.1.1
- Operating System and OS version: macOS Ventura 13.1
- Other information: I'm using IntelliJ, not the Processing application, and I'm subclassing PApplet and adding the Processing library to my program.
Possible Causes / Solutions
As I mentioned above, a clarifying comment would be a decent compromise if assigning true to finished in the PApplet draw method cannot be avoided.
As a beginner , can I work on this issue? What I Understood: Invoking super.draw() in subclass override draw() from PApplet will suspend the event handling. Do I have to fix the event handling problem or put a print statement suggesting the behavior ?
I hope that Ben will weigh in on this. If it's as simple as raising an exception or printing a warning to the console, then I wish someone would take care of this soon (for the sake of my CS students). However, I've seen some chatter about this issue that suggests that fixing this issue properly is complicated.