Opened 5 years ago

Last modified 2 months ago

#15645 assigned bug

Blinking background under the mouse cursor

Reported by: miqlas Owned by: X512
Priority: normal Milestone: Unscheduled
Component: Servers/app_server Version: R1/Development
Keywords: Cc:
Blocked By: Blocking: #15920
Platform: x86-64

Description

Since the recent "blinking" changes from X547 or X512 the background started to blink under the mouse cursor in Koder during text selection if a compilation runs in the background.

This is Haiku shredder 1 hrev53732 Jan 19 2020 08:40:01 x86_64 x86_64 Haiku

See the screenshot in the attachments.

Attachments (2)

zFYH.png (328.6 KB ) - added by miqlas 5 years ago.
zFYc.png (377.3 KB ) - added by miqlas 5 years ago.
Mouse cursor leaves tracelines in ActivityMonitor

Download all attachments as: .zip

Change History (16)

by miqlas, 5 years ago

Attachment: zFYH.png added

comment:1 by pulkomandy, 5 years ago

Owner: changed from nobody to X512
Status: newassigned

by miqlas, 5 years ago

Attachment: zFYc.png added

Mouse cursor leaves tracelines in ActivityMonitor

comment:2 by miqlas, 5 years ago

Mouse cursor leaves tracelines in ActivityMonitor

comment:3 by waddlesplash, 5 years ago

Component: - GeneralServers/app_server

X512, can you take a look?

comment:4 by X512, 5 years ago

Artifacts caused by moving cursor are present in Haiku for a long time since introducing screen double buffer. It caused by flushing back buffer at cursor location when it is not ready. There is no easy fix, but I have some ideas such as make additional buffer for every overlay layer objects (cursor and drag&drop contents).

Views that use backbuffer BBitmap and SetViewColor(B_TRANSPARENT_COLOR) like Koder and Qt applications were not affected by this, but after hrev53713 it are affected. Before hrev53713 only bitmap was painted on update so no flickering even if backbuffer was flushed early, but now background and then bitmap is painted. Fixing this require introducing some new API to distinguish transparent view and disabling background drawing.

comment:5 by X512, 5 years ago

In https://review.haiku-os.org/c/haiku/+/2275 B_TRANSPARENT_BACKGROUND flag is implemented. If this flag is not set, behavior is same as in BeOS. If flag is set, view become transparent, views under it are painted before.

This patch fixes flickering under cursor in Koder and other applications that use SetViewColor(B_TRANSPARENT_COLOR) and DrawBitmap.

comment:6 by waddlesplash, 5 years ago

but now background and then bitmap is painted.

I guess I'm confused as to why this is necessary (though app_server is not my forte to say the least.) I guess we are painting the parent view's background? Is there no other way to avoid that overdraw here? Is there no other way to decide that we do/do not want to paint the background besides adding a flag?

in reply to:  6 comment:7 by X512, 5 years ago

Replying to waddlesplash:

Is there no other way to avoid that overdraw here?

Currently there are no way to avoid overdraw. If background is set, it will be painted, if B_TRANSPARENT_COLOR is set, parent view will be painted before. In BeOS SetViewColor(B_TRANSPARENT_COLOR) disable background painting and NOT draw parent view before. This behavior was changed in hrev53713 to support transparent views. In https://review.haiku-os.org/c/haiku/+/2275 I restored BeOS behavior if flag is not set.

comment:8 by waddlesplash, 5 years ago

In the case of SetViewBitmap, could we skip drawing the background altogether if possible? Would that help with Koder (I guess it probably does not use SetViewBitmap, but maybe it could?)

comment:9 by pulkomandy, 5 years ago

Yes, but SetViewBitmap isn't properly implemented IIRC. Axeld has a very old branch with work on fixing this (possibly not even migrated from SVN?)

It would also allow to handle the desktop wallpaper properly, so it doesn't disappear when Tracker exits, I think.

comment:10 by pulkomandy, 5 years ago

Also you could do SetViewBitmap with a bitmap having an alpha channel, and still expect the parent view to draw, maybe?

in reply to:  9 comment:11 by X512, 5 years ago

Replying to pulkomandy:

Yes, but SetViewBitmap isn't properly implemented IIRC. Axeld has a very old branch with work on fixing this (possibly not even migrated from SVN?)

Any details?

comment:13 by waddlesplash, 5 years ago

AFAICT that is entirely about Desktop background drawing, I don't see any View related changes at all.

comment:14 by waddlesplash, 2 months ago

Blocking: 15920 added
Note: See TracTickets for help on using tickets.