mirror of
https://github.com/AvengeMedia/DankMaterialShell.git
synced 2026-04-13 01:02:18 -04:00
colorpicker: re-use Wayland buffer pools
This commit is contained in:
@@ -39,11 +39,10 @@ type LayerSurface struct {
|
|||||||
wlSurface *client.Surface
|
wlSurface *client.Surface
|
||||||
layerSurf *wlr_layer_shell.ZwlrLayerSurfaceV1
|
layerSurf *wlr_layer_shell.ZwlrLayerSurfaceV1
|
||||||
viewport *wp_viewporter.WpViewport
|
viewport *wp_viewporter.WpViewport
|
||||||
wlPool *client.ShmPool
|
wlPools [2]*client.ShmPool
|
||||||
wlBuffer *client.Buffer
|
wlBuffers [2]*client.Buffer
|
||||||
bufferBusy bool
|
slotBusy [2]bool
|
||||||
oldPool *client.ShmPool
|
needsRedraw bool
|
||||||
oldBuffer *client.Buffer
|
|
||||||
scopyBuffer *client.Buffer
|
scopyBuffer *client.Buffer
|
||||||
configured bool
|
configured bool
|
||||||
hidden bool
|
hidden bool
|
||||||
@@ -136,6 +135,7 @@ func (p *Picker) Run() (*Color, error) {
|
|||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
|
||||||
|
p.flushRedraws()
|
||||||
p.checkDone()
|
p.checkDone()
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -164,6 +164,15 @@ func (p *Picker) checkDone() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (p *Picker) flushRedraws() {
|
||||||
|
for _, ls := range p.surfaces {
|
||||||
|
if !ls.needsRedraw {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
p.redrawSurface(ls)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (p *Picker) connect() error {
|
func (p *Picker) connect() error {
|
||||||
display, err := client.Connect("")
|
display, err := client.Connect("")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -507,47 +516,45 @@ func (p *Picker) captureForSurface(ls *LayerSurface) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (p *Picker) redrawSurface(ls *LayerSurface) {
|
func (p *Picker) redrawSurface(ls *LayerSurface) {
|
||||||
|
slot := ls.state.FrontIndex()
|
||||||
|
if ls.slotBusy[slot] {
|
||||||
|
ls.needsRedraw = true
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
var renderBuf *ShmBuffer
|
var renderBuf *ShmBuffer
|
||||||
if ls.hidden {
|
switch {
|
||||||
|
case ls.hidden:
|
||||||
renderBuf = ls.state.RedrawScreenOnly()
|
renderBuf = ls.state.RedrawScreenOnly()
|
||||||
} else {
|
default:
|
||||||
renderBuf = ls.state.Redraw()
|
renderBuf = ls.state.Redraw()
|
||||||
}
|
}
|
||||||
if renderBuf == nil {
|
if renderBuf == nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if ls.oldBuffer != nil {
|
ls.needsRedraw = false
|
||||||
ls.oldBuffer.Destroy()
|
|
||||||
ls.oldBuffer = nil
|
|
||||||
}
|
|
||||||
if ls.oldPool != nil {
|
|
||||||
ls.oldPool.Destroy()
|
|
||||||
ls.oldPool = nil
|
|
||||||
}
|
|
||||||
|
|
||||||
ls.oldPool = ls.wlPool
|
|
||||||
ls.oldBuffer = ls.wlBuffer
|
|
||||||
ls.wlPool = nil
|
|
||||||
ls.wlBuffer = nil
|
|
||||||
|
|
||||||
|
if ls.wlPools[slot] == nil {
|
||||||
pool, err := p.shm.CreatePool(renderBuf.Fd(), int32(renderBuf.Size()))
|
pool, err := p.shm.CreatePool(renderBuf.Fd(), int32(renderBuf.Size()))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ls.wlPool = pool
|
ls.wlPools[slot] = pool
|
||||||
|
|
||||||
wlBuffer, err := pool.CreateBuffer(0, int32(renderBuf.Width), int32(renderBuf.Height), int32(renderBuf.Stride), uint32(ls.state.ScreenFormat()))
|
wlBuffer, err := pool.CreateBuffer(0, int32(renderBuf.Width), int32(renderBuf.Height), int32(renderBuf.Stride), uint32(ls.state.ScreenFormat()))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ls.wlBuffer = wlBuffer
|
ls.wlBuffers[slot] = wlBuffer
|
||||||
|
|
||||||
lsRef := ls
|
s := slot
|
||||||
wlBuffer.SetReleaseHandler(func(e client.BufferReleaseEvent) {
|
wlBuffer.SetReleaseHandler(func(e client.BufferReleaseEvent) {
|
||||||
lsRef.bufferBusy = false
|
ls.slotBusy[s] = false
|
||||||
})
|
})
|
||||||
ls.bufferBusy = true
|
}
|
||||||
|
|
||||||
|
ls.slotBusy[slot] = true
|
||||||
|
|
||||||
logicalW, logicalH := ls.state.LogicalSize()
|
logicalW, logicalH := ls.state.LogicalSize()
|
||||||
if logicalW == 0 || logicalH == 0 {
|
if logicalW == 0 || logicalH == 0 {
|
||||||
@@ -566,7 +573,7 @@ func (p *Picker) redrawSurface(ls *LayerSurface) {
|
|||||||
}
|
}
|
||||||
_ = ls.wlSurface.SetBufferScale(bufferScale)
|
_ = ls.wlSurface.SetBufferScale(bufferScale)
|
||||||
}
|
}
|
||||||
_ = ls.wlSurface.Attach(wlBuffer, 0, 0)
|
_ = ls.wlSurface.Attach(ls.wlBuffers[slot], 0, 0)
|
||||||
_ = ls.wlSurface.Damage(0, 0, int32(logicalW), int32(logicalH))
|
_ = ls.wlSurface.Damage(0, 0, int32(logicalW), int32(logicalH))
|
||||||
_ = ls.wlSurface.Commit()
|
_ = ls.wlSurface.Commit()
|
||||||
|
|
||||||
@@ -634,7 +641,7 @@ func (p *Picker) setupPointerHandlers() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
p.activeSurface.state.OnPointerMotion(e.SurfaceX, e.SurfaceY)
|
p.activeSurface.state.OnPointerMotion(e.SurfaceX, e.SurfaceY)
|
||||||
p.redrawSurface(p.activeSurface)
|
p.activeSurface.needsRedraw = true
|
||||||
})
|
})
|
||||||
|
|
||||||
p.pointer.SetLeaveHandler(func(e client.PointerLeaveEvent) {
|
p.pointer.SetLeaveHandler(func(e client.PointerLeaveEvent) {
|
||||||
@@ -655,7 +662,7 @@ func (p *Picker) setupPointerHandlers() {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
p.activeSurface.state.OnPointerMotion(e.SurfaceX, e.SurfaceY)
|
p.activeSurface.state.OnPointerMotion(e.SurfaceX, e.SurfaceY)
|
||||||
p.redrawSurface(p.activeSurface)
|
p.activeSurface.needsRedraw = true
|
||||||
})
|
})
|
||||||
|
|
||||||
p.pointer.SetButtonHandler(func(e client.PointerButtonEvent) {
|
p.pointer.SetButtonHandler(func(e client.PointerButtonEvent) {
|
||||||
@@ -679,17 +686,13 @@ func (p *Picker) cleanup() {
|
|||||||
if ls.scopyBuffer != nil {
|
if ls.scopyBuffer != nil {
|
||||||
ls.scopyBuffer.Destroy()
|
ls.scopyBuffer.Destroy()
|
||||||
}
|
}
|
||||||
if ls.oldBuffer != nil {
|
for i := range ls.wlBuffers {
|
||||||
ls.oldBuffer.Destroy()
|
if ls.wlBuffers[i] != nil {
|
||||||
|
ls.wlBuffers[i].Destroy()
|
||||||
}
|
}
|
||||||
if ls.oldPool != nil {
|
if ls.wlPools[i] != nil {
|
||||||
ls.oldPool.Destroy()
|
ls.wlPools[i].Destroy()
|
||||||
}
|
}
|
||||||
if ls.wlBuffer != nil {
|
|
||||||
ls.wlBuffer.Destroy()
|
|
||||||
}
|
|
||||||
if ls.wlPool != nil {
|
|
||||||
ls.wlPool.Destroy()
|
|
||||||
}
|
}
|
||||||
if ls.viewport != nil {
|
if ls.viewport != nil {
|
||||||
ls.viewport.Destroy()
|
ls.viewport.Destroy()
|
||||||
|
|||||||
@@ -274,6 +274,12 @@ func (s *SurfaceState) FrontRenderBuffer() *ShmBuffer {
|
|||||||
return s.renderBufs[s.front]
|
return s.renderBufs[s.front]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *SurfaceState) FrontIndex() int {
|
||||||
|
s.mu.Lock()
|
||||||
|
defer s.mu.Unlock()
|
||||||
|
return s.front
|
||||||
|
}
|
||||||
|
|
||||||
func (s *SurfaceState) SwapBuffers() {
|
func (s *SurfaceState) SwapBuffers() {
|
||||||
s.mu.Lock()
|
s.mu.Lock()
|
||||||
s.front ^= 1
|
s.front ^= 1
|
||||||
|
|||||||
Reference in New Issue
Block a user