Wayland (Português)

Wayland é um protocolo de servidor de exibição. Seu objetivo é se tornar o sucessor do Sistema de janelas X. Você pode encontrar uma comparação entre Wayland e Xorg no Wikipedia.

Status de tradução: Esse artigo é uma tradução de Wayland. Data da última tradução: 2021-07-28. Você pode ajudar a sincronizar a tradução, se houver alterações na versão em inglês.

Servidores de exibição que usam o protocolo Wayland são chamados de compositores devido a também agirem como um gerenciador de janelas de composição. Abaixo você pode encontrar uma lista de compositores Wayland.

Para executar aplicações X11 legadas sem problemas de compatibilidade, XWayland pode ser usado, que oferece um Servidor X no Wayland.

Requerimentos

A maioria do compositores Wayland somente funcionam em sistemas que usam Kernel mode setting. Wayland por si só não provê um ambiente gráfico; para isto você também precisa de um compositor (veja a seção seguinte), ou um ambiente desktop que inclui um compositor (e.x. GNOME ou KDE.

Para o driver GPU e o compositor Wayland serem compatíveis eles devem suportar a mesma buffer API. Existem duas principais APIs: GBM e EGLStreams.

Buffer APISuporte de driver GPUSuporte de compositores Wayland
GBMTodos exceto NVIDIATodos
EGLStreamsNVIDIAGNOME, KDE, Weston (com uma modificação de terceiros)

Compositores

Veja Window manager#Types para diferenças entre Tiling e Stacking.

Tiling

https://github.com/project-repo/cagebreak || cagebreakAUR cagebreak-binAUR
  • Cardboard Compositor scrolling, inspirado pelo PaperWM, baseado no wlroots.
https://gitlab.com/cardboardwm/cardboard || cardboard-gitAUR
  • dwl Compositor Wayland parecido com o dwm baseado no wlroots.
https://github.com/djpohly/dwl || dwlAUR
  • japokwm Compositor Wayland tiling dinâmico baseado na criação de layouts, baseado no wlroots.
https://github.com/werererer/japokwm || japokwm-gitAUR
  • Qtile Um gerenciador de janelas e compositor Wayland cheio de funcionalidades e configurável ecrito e configurado em Python.
https://github.com/qtile/qtile || qtile
  • river Compositor Wayland tiling dinâmico inspirado pelo dwm e bspwm.
https://github.com/ifreund/river || river-gitAUR

Stacking

https://www.enlightenment.org/ || enlightenment
  • wayfire Compositor 3D inspirado pelo Compiz e baseado no wlroots.
https://wayfire.org/ || wayfireAUR
  • wio Compositor baseado no wlroots que têm como objetivo replicar a aparência e sentimento do ambiente Rio do Plan 9.
https://wio-project.org/[link inativo 2022-09-23 ] || not packaged? search in AUR

Outros

Alguns destes acima podem suportar gerenciadores de exibição. Verifique para ver como eles são inicializados.

Gerenciadores de exibição

Gerenciadores de exibição listados abaixo suportam lançar compositores Wayland. A coluna Tipo indica se o gerenciador de exibição suporta ou não se executar em Wayland.

Nome Tipo Descrição
GDM Roda em Wayland Gerenciador de login do GNOME.
greetd Daemon de login Daemon de login minímo e flexível.
LightDM Roda em X11 Gerenciador de login TUI escrito em C
Ly Roda no console TUI display manager written in C
SDDM Roda em X11 Gerenciador de login feito em QML.
tbsm Roda no console Simples lançador CLI de sessão escrito em bash puro.

Bibliotecas GUI

Veja detalhes no site oficial.

GTK

Os pacotes e tem o backend Wayland já habilitado. GTK irá ser executado por padrão em Wayland, mas é possível sobrescrever isto para Xwayland ao modificar a variável de ambiente: .

Qt

Para habilitar o suporte ao Wayland no Qt 5 ou 6, instale o pacote ou , respectivamente.

Para rodar um programa Qt com o plugin Wayland , use -platform wayland ou a variável de ambiente . Para forçar o uso do X11 numa sessão Wayland, use QT_QPA_PLATFORM=xcb. Isto pode ser necessário para alguns programas proprietários que não usam a implementação do Qt presente no sistema, como .

Em alguns compositores, como o sway, programas Qt executados nativamente em Wayland podem perder funcionalidade. Por exemplo, KeepassXC não vai conseguir minimizar para a barra. Isto pode ser resolvido ao instalar e definindo antes de executar o programa.

Clutter

O toolkit Clutter suporta o backend Wayland e isto possibilita que ele rode como um cliente Wayland. O backend já é habilitado por padrão no pacote .

Para rodar um programa Clutter em Wayland, defina: .

SDL2

Para rodar um programa SDL2 no Wayland, defina .

GLFW

Para usar GLFW com o backend Wayland, instale o pacote glfw-wayland (ao invés do ).

GLEW

O pacote atualmente ainda não funciona com muitas aplicações baseada no GLEW, então a única opção é usar com Xwayland. Veja FS#62713.

EFL

EFL tem suporte completo ao Wayland. Para rodar um programa EFL no Wayland, veja a página do projeto.

winit

Winit é uma biblioteca de gerenciamento de janela em Rust. Por padrão utiliza o backend Wayland, mas é possível forçar o uso do XWayland ao modificar a variável de ambiente: .

Electron

Para usar aplicações baseadas no nativamente no Wayland, crie ou edite o arquivo para adicionar as seguintes opções.

Note que versões mais antigas do electron precisam de seu próprio arquivo . Por exemplo, se você tem o pacote electron12AUR instalado, você pode querer executar

$ ln -s electron-flags.conf electron12-flags.conf

de dentro do seu diretório (ou manter um arquivo separado se quer que diferentes versões do usem diferentes opções em tempo de execução).

XWayland

XWayland é um Servidor X que executa no Wayland. Isto oferece compatibilidade para aplicações X11 legadas.

Para usa-lo, instale o pacote .

XWayland é iniciado pelo compositor, então você deve verificar pela compatibilidade XWayland e instruções de como iniciar o XWayland com o compositor de sua escolha.

Driver da Nvidia

Nota: Drivers da Nvidia antes da versão 470 (e.x. nvidia-390xx-dkmsAUR) não suportam aceleração de hardware pelo XWayland, fazendo com que aplicações não Wayland sofram com pouco desempenho em sessões Wayland.

Note que é necessário habilitar DRM KMS. Também veja informação adicional na documentação oficial e sobre o seu gerenciador de exibição (e.x. GDM).

Resolução de problemas

Correção de cor

Veja Backlight#Color correction.

Tela lenta, glitches gráficos, e crashes

Usuários do gnome-shell podem sofrer problemas na tela quando eles mudam para Wayland do X. Uma das causas desse problema pode ser o definido para o gnome-shell baseado no Xorg. Tente remover isto do ou outros arquivos rc para ver se tudo volta ao normal.

Cannot open display: :0 com programas feitos em Electron

Tenha certeza que você não definiu GDK_BACKEND=wayland. Definir isso globalmente irá quebrar programas Electron.

Exibição remota

  • (20200206) (usado pelo Sway) oferece um backend VNC com desde a versão 0.10. Suporte ao backend RDP foi removido.

.

  • (20180401) mutter tem agora desktop remoto habilitado no tempo de compilação, veja e para detalhes.
  • Existe um merge do FreeRDP no Weston em 2013, habilitado com uma flag de compilação. O pacote vem com isso habilitado desde a versão 6.0.0.
  • é um proxy transparente para programas Wayland, com um comando que roda via SSH.

Captação de entradas nos jogos, desktop remoto e janelas VM

Diferente do Xorg, Wayland não permite captação exclusiva de entrada, também conhecido como captação ativa ou explicita (exemplo teclado, mouse), ao invés disso, depende do compositor Wayland para direcionar os atalhos do teclado e confinar o ponteiro para a janela do programa.

Esta mudança na captação de entrada quebra o atual comportamento dos programas:

  • Combinação de teclas e modificadores irão ser pegos pelo compositor e não serão enviados para o desktop remoto e janelas de máquina virtual.
  • O mouse não irá ser restrito a janela da aplicação, isto pode causar um efeito de paralaxe onde a localização do ponteiro dentro da janela da máquina virtual ou desktop remoto é mal interpretado do host.

Isto é resolvido adicionando extensões para o protocolo Wayland e XWayland. O suporte para estas extensões precisam ser adicionados para compositores Wayland. Os clientes nativos do Wayland, toolkits widget (exemplo GTK, Qt) ou as próprias aplicações, se nenhum toolkit está sendo usado, também precisam suportar estas extensões. Programas Xorg não precisam de mudança devido a existência do XWayland.

Estas extensões já estão incluídas no , e suportadas pelo .

Extensões relacionadas são:

Compositores que suportam Wayland:

Toolkits widget que suportam:

  • GTK desde a versão 3.22.18.

Veja também

gollark: "Worked".
gollark: Well, the garbage collector does it apparently.
gollark: You can't close files with anything other then their handle methods.
gollark: It's a program which (theoretically...) allows you (on Linux) to mount a computer's filesystem as if it's on your local machine.
gollark: Maybe if you use CCFuse and run the actual git commands outofgame?
This article is issued from Archlinux. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.