Row (linha) é um controle que serve de container para outros controles e os exibe horizontalmente. Ele possui propriedades, eventos e métodos relativos ao layout e gerenciamento de rolagem da página (scroll) para evitar overflow (quando o conteúdo ocupa áerea maior que a disponível na página).
Propriedades de Row
Propriedades
Descrição
alignment
alinhamento horizontal dos filhos.
A propriedade MainAxisAlignment recebe um ENUM com os valores:
START(default) alinha à esquerda da Linha
END
CENTER
SPACE_BETWEEN
SPACE_AROUND
SPACE_EVENLY
auto_scroll
booleano, auto_scroll=True para mover a posição de scroll para o final quando ocorre atualização dos filhos. Para que o método scroll_to() funcione é necessário ajustar auto_scroll=False.
controls
uma lista de controles a serem exibidos na linha.
run_spacing
espaçamento entre as várias linhas (runs) quando wrap=True. Default: 10.
Linhas adicionais aparecem quando os controles não cabem dentro de uma linha única.
scroll
permite rolagem horizontal da linha para evitar overflow. A propriedade pode receber o ENUM ScrollMode com os valores:
None (default): não é rolagem e pode haver overflow.
AUTO: rolagem habilitada e a barra de rolagem só aparece quando ocorre o scroll.
ADAPTIVE: rolagem habilitada e a barra sempre visível quando aplicativo roda na web ou desktop.
ALWAYS: rolagem habilitada e a barra sempre visível.
HIDDEN: rolagem habilitada e a barra sempre oculta.
spacing
espaçamento entre controles na linha. Default: 10 pixeis. O espaçamento só é aplicado quando alignment é start, end ou center.
on_scroll_interval
limitação para o evento on_scroll em milisegundos. Default: 10.
tight
booleano, espaço a ser ocupado horizontalmente. Default: tight = False, usar todo o espaço os controles.
vertical_alignment
alinhamento vertical. A propriedade pode receber o ENUM CrossAxisAlignment os valores:
START (default)
CENTER
END
STRETCH
BASELINE
wrap
booleano, se wrap=True os controles filhos serão colocados em linhas adicionais (chamadas runs), caso não caibam em uma única linha.
Métodos de Row
Método
Descrição
scroll_to(offset, delta, key, duration, curve)
move a posição de rolagem para o offset absoluto, para um salto (delta) ou para o controle com key especificada.
Detalhes são idênticos ao do método de Column.scroll_to().
Eventos de Row
Evento
Dispara quando
on_scroll
a posição de rolagem da linha é alterada por um usuário. Consulte Column.on_scroll() para detalhes e exemplos do evento.
Uso das propriedades de row
No código abaixo são criados 30 controles container numerados que são dispostos em uma linha. Dois controle de deslizar (slide) ajustam as propriedades row.width (o número de colunas em cada linha) e row.spacing (o espaçamento entre cada objeto. Quando o número de objetos em uma linha é maior que o espaço permite, novas linhas são inseridas (runs).
import flet as ft # era 52
def main(page: ft.Page):
def items(count):
items = []
for i in range(1, count + 1):
items.append(ft.Container(ft.Text(value=str(i), color="white", size=20), alignment=ft.alignment.center,
width=40, height=40, bgcolor="#40A4D2", border_radius=ft.border_radius.all(10)))
return items
def muda_largura(e):
linha.width = float(e.control.value)
linha.update()
def muda_separa(e):
linha.spacing = int(e.control.value)
linha.update()
slid_separa = ft.Slider(min=0, max=50, divisions=50, value=0, label="{value}", on_change=muda_separa,)
slid_largura = ft.Slider(min=0, max=page.window_width, divisions=20, value=page.window_width,
label="{value}", on_change=muda_largura,)
linha = ft.Row(wrap=True, spacing=10, run_spacing=10, controls=items(30), width=page.window_width,)
txt1 = ft.Text("O primeiro controle seleciona o número de colunas:")
txt2 = ft.Text("O segundo controle seleciona espaçamento entre colunas:")
page.add(ft.Column([txt1, slid_largura,]),ft.Column([txt2, slid_separa,]), linha,)
ft.app(target=main)
O código gera, em algum ajuste dos controles de deslizar, a janela abaixo.
Column é um controle que serve de container para outros controles e os exibe verticalmente. Ele possui propriedades eventos e métodos relativos ao layout e gerenciamento do rolamento da página (scroll) para evitar overflow (quando o conteúdo ocupa áerea maior que a disponível na página.
Propriedades de Column
Propriedades
Descrição
alignment
define como os controles filhos devem ser colocados verticalmente.
A propriedade MainAxisAlignment recebe um ENUM com os valores:
START(default) alinha à esquerda da Linha
END
CENTER
SPACE_BETWEEN
SPACE_AROUND
SPACE_EVENLY
auto_scroll
auto_scroll=True para mover a posição de scroll o final quando ocorre atualização dos filhos. Para que o método scroll_to() funcione devemos fazer auto_scroll=False.
controls
lista de controles a serem exibidos na coluna.
horizontal_alignment
posicionamento horizontal dos controles filhos.
A propriedade recebe o ENUM CrossAxisAlignment com os valores:
START(default) alinha à esquerda da Linha
END
CENTER
STRETCH
BASELINE
on_scroll_interval
limita o evento on_scroll (em milisegundos). Default: 10.
scroll
habilita a rolagem vertical na coluna para evitar overflow de conteúdo.
A propriedade recebe um ENUM opcional ScrollMode com valores:
None (default): coluna não é rolável e pode haver overflow.
AUTO: rolagem habilitada e a barra de rolagem só aparece quando a rolagem é necessária.
ADAPTIVE: rolagem habilitada e a barra sempre visível em aplicativos na web ou desktop.
ALWAYS: rolagem habilitada e a barra sempre vivível.
HIDDEN: rolagem habilitada, a barra de rolagem está sempre oculta.
spacing
espaçamento entre os controles da coluna. Default: 10 pixeis. O espaçamento só é aplicado quando alignment = start, end, center.
run_spacing
espaçamento entre “runs” quando wrap=True. Default: 10.
tight
espaçamento vertical. Default: False (alocar todo o espaço para filhos).
wrap
se wrap=True a coluna distribuirá os controles filho em colunas adicionais (runs) se não couberem em uma coluna.
Métodos de Column
Método
Descrição
scroll_to(
offset, delta,
key, duration,
curve)
move a posição de rolagem para o offset absoluto, para um salto (delta) ou para o controle com key especificada.
Por exemplo:
(1) offset é a posição do controle, um valor entre a extensão mínima e máxima do controle de scroll.
(2) offset negativo conta a partir do final do scroll. offset=-1 para posicionar no final.
(3) delta move o scroll relativo à posição atual. Rola para trás, se negativo.
(4) key move o scroll para a posição especificada com key.
A maioria dos controles do Flet tem a propriedade key (equivalente ao global key do Flutter. keydeve ser única para toda a page/view. duration define a duração da animação de rolagem, em milisegundos. Default: 0 (sem animação). curve configura a curva de animação. Default: ft.AnimationCurve.EASE.
Eventos de Column
Evento
Dispara quando
on_scroll
a posição de rolagem é alterada por um usuário.
O argumento do gerenciador de eventos é instância da ft.OnScrollEvent com as propriedades:
event_type (str), tipo do evento de rolagem:
start: início da rolagem;
update: controle de rolagem mudou de posição;
end: início da rolagem (parou de rolar);
user: usuário mudou a direção da rolagem;
over: controle ficou inalterado por estar no início ou final;
pixels(float): posição de rolagem atual, em pixeis lógicos.
min_scroll_extent (float): valor mínimo no intervalo permitido, em pixeis.
max_scroll_extent (float): valor máximo no intervalo permitido, em pixeis.
viewport_dimension (float): extensão da viewport.
scroll_delta (float): distância rolada, em pixeis. Definido apenas em eventos update.
direction (str) : direção da rolagem: idle, forward, reverse. Definido apenas em evento user.
overscroll (float): número de pixeis não rolados, por overflow. Definido apenas em eventos over.
velocity (float): velocidade na posição de ScrollPosition quando ocorreu overscroll. Definido apenas em eventos over.
Expandindo controles na linha e na coluna
Todos os controles possuem a propriedade expand que serve para expandi-lo para preencher os espaços disponíveis dentro de uma linha. Ela pode receber um booleano ou um inteiro. expand=True significa expandir o controle para preencher todo o espaço. expand=int introduz um “fator de expansão” especificando como dividir um espaço com outros controles expandidos na mesma linha, ou coluna. O código:
cria uma linha contendo um TextField que ocupa o espaço disponível, e um ElevatedButton, sem expansão. A expansão é calculada em termos do tamanho de todos os controle na linha. É possível fornecer fatores que definem a proporção de expansão de cada controle. Por exemplo:
linha = ft.Row([
ft.Container(expand=1, content=ft.Text("A")),
ft.Container(expand=3, content=ft.Text("B")),
ft.Container(expand=1, content=ft.Text("C"))
])
cria uma linha com 3 controles ocupando 1, 3, 1 partes em 5, como exibido na figura,
Percentualmente a largura resultante de um filho é calculada como largura = expand / soma( todas as expands) * 100%.
Da mesma forma um controle filho em uma coluna pode ser expandido para preencher o espaço vertical disponível. Por exemplo, o código abaixo cria uma coluna com um Container que ocupando todo o espaço disponível e um controle Text na parte inferior servindo como uma barra de status:
coluna = ft.Column([
ft.Container(expand=True, content=ft.Text("Esse será expandido")),
ft.Text("Um texto usado como label")
])
Assim como no controle das linhas, podemos usar fatores numéricos em expand=n.
A palavra container do inglês é traduzida como contêiner (pt-br), plural contêineres. Para não criar confusão com a palavra técnica nós o chamaremos aqui por container, containers.
Um aplicativo do Flet abre sempre uma page que serve de container para o objeto View. Uma View é criado automaticamente quando uma nova sessão é iniciada. Ela é basicamente uma coluna (column) básica, que abriga todos os demais controles que serão inseridos na página. Dessa forma ele tem comportamento semelhante ao de uma column, e as mesmas propriedades. Uma descrição resumida será apresentada aqui. Para maiores detalhes consulte a descrição de column.
O objeto View é o componente visual de uma página Flet, responsável por renderizar os elementos da UI e gerenciar seu estado. Ele pode abrigar outros objetos como botões, campos de texto, imagens, etc, e organizá-los em uma estrutura hierárquica. Esses elementos são então renderizados na tela. O objeto View também possui métodos para lidar com eventos do usuário, como cliques em botões ou textos digitados nas caixas de texto.
Por exemplo, o código:
page.controls.append(ft.Text("Um texto na página!"))
page.update()
# ou, o que é equivalente
page.add(ft.Text("Um texto na página!"))
insere o texto na View que está diretamente criada sobre page. View possui as seguintes propriedades e métodos.
View: Propriedades
Propriedade
Descrição
appbar
recebe um controle AppBar para exibir na parte superior da página.
auto_scroll
Booleano. True para que a barra de rolagem se mova para o final quando os filhos são atualizados. Para que scroll_to() funcione deve ser atribuído auto_scroll=False.
bgcolor
Cor de fundo da página.
controls
Lista de controles a serem inseridos na página. O último controle da lista pode se removido com page.controls.pop(); page.update().
fullscreen_dialog
Booleano. True se a página atual é um diálogo em tela cheia.
route
Rota da visualização (não usada atualmente). Pode ser usada para atualizar page.route em caso de nova visualização.
floating_action_button
Recebe um controle FloatingActionButton a ser exibido no alto da página.
horizontal_alignment
Alinhamento horizontal dos filhos. Default: horizontal_alignment=CrossAxisAlignment.START.
on_scroll_interval
Definição do intervalo de tempo para o evento on_scrollo, em milisegundos. Default: 10.
padding
Espaço entre o conteúdo do objeto e suas bordas, em pixeis. Default: 10.
scroll
Habilita rolagem (scroll) vertical para a página, evitando overflow. O valor da propriedade está em um ENUM ScrollMode com as possibilidades:
None (padrão): nenhum scroll. Pode haver overflow.
AUTO: scroll habilitado, a barra só aparece quando a rolagem é necessária.
ADAPTIVE: scroll habilitado, a barra de rolagem visível quando aplicativo é web ou desktop.
ALWAYS: scroll habilitado, a barra sempre exibida.
HIDDEN: scroll habilitado, barra de rolagem invisível.
spacing
Espaço vertical entre os controles da página, em pixeis. Default: 10. Só aplicado quando alignment = start, end, center.
vertical_alignment
Alinhamento vertical dos filhos. A propriedade está em um ENUM MainAxisAlignmente com as possibilidades:
Move a barra de scroll para uma posição absoluta ou salto relativo para chave especificada.
View: Evento
Evento
Descrição
on_scroll
Dispara quando a posição da barra de rolagem é alterada pelo usuário.
O controle View é útil em situações que se apresenta mais em uma visualização na mesma página e será visto mais tarde com maiores detalhes.
Flet: Container
Um objeto Container é basicamente um auxiliar de layout, um controle onde se pode inserir outros controles, permitindo a decoração de cor de fundo, borda, margem, alinhamento e preenchimento. Ele também pode responder a alguns eventos.
Como exemplo, o código abaixo:
import flet as ft
def main(page: ft.Page):
page.title = "Contêineres com cores de fundo"
def cor(e):
c4 = ft.Container(content=ft.Text("Outro conteiner azul!"), bgcolor=ft.colors.BLUE, padding=5)
page.add(c4)
c1 = ft.Container(content=ft.ElevatedButton("Um botão \"Elevated\""),
bgcolor=ft.colors.YELLOW, padding=5)
c2 = ft.Container(content=ft.ElevatedButton("Elevated Button com opacidade=0.5",
opacity=0.5), bgcolor=ft.colors.YELLOW, padding=5)
c3 = ft.Container(content=ft.Text("Coloca outra área azul"),
bgcolor=ft.colors.YELLOW, padding=5, on_click=cor)
page.add(c1, c2, c3)
ft.app(target=main)
gera a janela na figura 1, após 1 clique no botão c3.
O container c3 reage ao evento clique, adicionando um (ou mais) botão azul à janela.
Container: Propriedades
A figura 2 mostra o esquema de espaçamentos entre controles: a largura e altura (width, height) do container, a margem (margin) entre a caixa de decoração e o container, a borda (border) da caixa e o espaçamento interno (padding) entre o controle e a caixa.
Propriedade
Descrição
alignment
Alinhamento do controle filho dentro do Container para exibir na parte superior da página. Alignment é uma instância do objeto alignment.Alignment com propriedades x e y que representam a distância do centro de um retângulo.
x=0, y=0: o centro do retângulo,
x=-1, y=-1: parte superior esquerda do retângulo,
x=1.0, y=1.0: parte inferior direita do retângulo.
Constantes de alinhamento pré-definidas no módulo flet.alignment são: top_left, top_center, top_right, center_left, center, center_right, bottom_left, bottom_center, bottom_right. Por exemplo, mostrado na figura 4:
Ativa a animação predefinida do container, alterando valores de suas propriedades de modo gradual. O valor pode ser um dos seguintes tipos:
bool: True para ativar a animação do container com curva linear de duração de 1000 milisegundos.
int: ajusta tempo em milisegundos, com curva linear.
animation: Animation(duration: int, curve: str): ativa animação do container com duração e curva de transição especificadas.
Por exemplo:
import flet as ft
def main(page: ft.Page):
c = ft.Container(width=200, height=200, bgcolor="red", animate=ft.animation.Animation(1000, "bounceOut"))
def animar_container(e):
c.width = 100 if c.width == 200 else 200
c.height = 100 if c.height == 200 else 200
c.bgcolor = "blue" if c.bgcolor == "red" else "red"
c.update()
page.add(c, ft.ElevatedButton("Animate container", on_click=animar_container))
ft.app(target=main)
O código resulta na animação mostrada abaixo, na figura 5:
bgcolor
Cor de fundo do container.
blend_mode
modo de mistura (blend) de cores ou gradientes no fundo container.
blur
Aplica o efeito de desfoque (blur) gaussiano sobre o container.
O valor desta propriedade pode ser um dos seguintes:
um número: especifica o mesmo valor para sigmas horizontais e verticais, por exemplo 10.
uma tupla: especifica valores separados para sigmas horizontais e verticais, por exemplo (10, 1).
uma instância de ft.Blur: especifica valores para sigmas horizontais e verticais, bem como tile_mode para o filtro. tile_mode é o valor de ft.BlurTileMode tendo como default ft.BlurTileMode.CLAMP.
border
Borda desenhada em torno do controle e acima da cor de fundo. Bordas são descritas por uma instância de border.BorderSide, com as propriedades: width (número) e color (string). O valor da propriedade border é instância de border.Borderclasse, descrevendo os 4 lados do retângulo. Métodos auxiliares estão disponíveis para definir estilos de borda:
Permite especificar (opcional) o raio de arredondamento das bordas. O raio é instância de border_radius.BorderRadius com as propriedades: top_left, top_right, bottom_left, bottom_right. Esses valores podem ser passados no construtor da instância, ou por meio de métodos auxiliares:
Define a opacidade da imagem ao mesclar com um plano de fundo: valor entre 0.0 e 1.0.
image_repeat
Descrita junto com o objeto image.
image_src
Define imagem do plano de fundo.
image_src_base64
Define imagem codificada como string Base-64 como plano de fundo do container.
ink
True para efeito de ondulação quando o usuário clica no container. Default: False.
margin
Espaço vazio que envolve o controle. margin é uma instância de margin.Margin, definindo a propriedade para os 4 lados do retângulo: left, top, right e bottom. As propriedades podem ser dadas no construtor ou por meio de métodos auxiliares:
margin.all(value)
margin.symmetric(vertical, horizontal)
margin.only(left, top, right, bottom)
Por exemplo:
container_1.margin = margin.all(10)
container_2.margin = 20 # same as margin.all(20)
container_3.margin = margin.symmetric(vertical=10)
container_3.margin = margin.only(left=10)
padding
Espaço vazio de decoração entre borda do objeto e seu container. Padding é instância da padding.Padding com propriedades definidas como padding para todos os lados do retângulo: left, top, right e bottom. As propriedades podem ser dadas no construtor ou por meio de métodos auxiliares:
padding.all(value: float)
padding.symmetric(vertical, horizontal)
padding.only(left, top, right, bottom)
Por exemplo:
container_1.padding = ft.padding.all(10)
container_2.padding = 20 # same as ft.padding.all(20)
container_3.padding = ft.padding.symmetric(horizontal=10)
container_4.padding=padding.only(left=10)
shadow
Efeito de sombras projetadas pelo container. O valor dessa propriedade é uma instância ou uma lista de ft.BoxShadow, com as seguintes propriedades:
spread_radius: espalhamento, quanto a caixa será aumentada antes do desfoque. Default: 0.0.
blur_radius: desvio padrão da gaussiano de convolução da forma. Default: 0.0.
color: Cor da sombra.
offset: Uma instância de ft.Offsetclasse, deslocamentos da sombra, relativos à posição do elemento projetado. Os deslocamentos positivos em x e y deslocam a sombra para a direita e para baixo. Deslocamentos negativos deslocam para a esquerda e para cima. Os deslocamentos são relativos à posição do elemento que o está projetando. Default: ft.Offset(0,0).
blur_style: tipo de estilo, ft.BlurStyleque a ser usado na sombra. Default: ft.BlurStyle.NORMAL.
A forma do conteiner. O valor é ENUM BoxShape: RECTANGLE (padrão), CIRCLE
theme_mode
O ajuste do theme_mode redefine o tema usado no container e todos os objetos dentro dele. Se não for definido o tema em theme é válido para o container e seus filhos.
theme
Ajuste o tema global e dos filhos na árvore de controle.
Segue um exemplo de uso:
import flet as ft
def main(page: ft.Page):
page.theme = ft.Theme(color_scheme_seed=ft.colors.RED)
b1 = ft.ElevatedButton("Botão com tema da página")
b2 = ft.ElevatedButton("Botão com tema herdado")
b3= ft.ElevatedButton("Botão com tema dark")
c1 = ft.Container(
b1,
bgcolor=ft.colors.SURFACE_TINT,
padding=20,
width=300
)
c2 = ft.Container(
b2,
theme=ft.Theme(
color_scheme=ft.ColorScheme(primary=ft.colors.PINK)
),
bgcolor=ft.colors.SURFACE_VARIANT,
padding=20,
width=300
)
c3 = ft.Container(
b3,
theme=ft.Theme(
color_scheme_seed=ft.colors.INDIGO
),
theme_mode=ft.ThemeMode.DARK,
bgcolor=ft.colors.SURFACE_VARIANT,
padding=20,
width=300
)
page.add(c1, c2, c3)
ft.app(main)
O tema principal da página é definido em page.theme, usando um seed vermelho. Os botões b1 e b2 simnplesmente herdam o tema da página. O botão b3 está no container definido com theme_mode=ft.ThemeMode.DARK, exibindo o tema escuro. O código gera a janela mostrada na figura 6.
Vale lembrar que c1 = ft.Container(b1,...) é equivalente à c1 = ft.Container(content = b1,...) sendo que o content só pode ser omitido se o conteúdo for inserido como primeiro parâmetro.urlDefine a URL a ser abertta quando o container é clicado, disparando o evento on_click.url_target
Define onde abrir URL no modo web:
_blank (default): em nova janela ou aba,
_self: na mesma janela ou aba aberta.
Container: Eventos
Evento
Dispara quando
on_click
o usuário clica no container.
class ft.ContainerTapEvent():
local_x: float
local_y: float
global_x: float
global_y: float
Obs.: O objeto de evento e é uma instância de ContainerTapEvent, exceto se a propriedade ink = True. Nesse caso e será apenas ControlEvent com data vazio.
As propriedades e.local_x e e.local_y se referem à posição dentro do container c1, enquanto e.global_x e e.global_y se referem à posição global, dentro da página.
on_hover
o cursor do mouse entra ou abandona a área do container. A propriedade data do evento contém um string (não um booleano) e.data = "true" quando o cursor entra na área, e e.data = "false" quando ele sai.
Um exemplo de um container que altera sua cor de fundo quando o mouse corre sobre ele:
import flet as ft
def main(page: ft.Page):
def on_hover(e):
e.control.bgcolor = "blue" if e.data == "true" else "red"
e.control.update()
c1 = ft.Container(width=100, height=100, bgcolor="red",
ink=False, on_hover=on_hover)
page.add(c1)
ft.app(target=main)
on_long_press
quando o container recebe um click longo (pressionado por um certo tempo).
Detalhes sobre o gradiente de cores
O gradiente na cor de fundo admite como valor uma instância de uma das classes: LinearGradient, RadialGradient e SweepGradient.
A primeira imagem é gerada com LinearGradient, a segunda com RadialGradient e a última com SweepGradient.
São propriedades da classe LinearGradient:
begin
instância de Alignment. Posicionamento inicial (0.0) do gradiente.
end
instância de Alignment. Posicionamento final (1.0) do gradiente.
colors
cores assumidas pelo gradiente a cada parada. Essa lista deve ter o mesmo tamanho que stops se a lista for não nula. A lista deve ter pelo menos duas cores.
stops
lista de valores de 0.0 a 1.0 marcando posições ao longo do gradiente. Se não nula essa lista deve ter o mesmo comprimento que colors. Se o primeiro valor não for 0.0 fica implícita uma parada em 0,0 com cor igual à primeira cor em colors. Se o último valor não for 1.0 fica implícita uma parada em 1.0 e uma cor igual à última cor em colors.
tile_mode
como o gradiente deve preencher (tile) a região antes de begin depois de end. O valor é um ENUM GradientTileMode com valores: CLAMP (padrão), DECAL, MIRROR, REPEATED.
rotation
rotação do gradiente em radianos, em torno do ponto central de sua caixa container.
Mais Informações:
Gradiente linear na documentação do Flutter.
Unidade de medida de radianos na Wikipedia.
São propriedades da classe RadialGradient:
colors, stops, tile_mode, rotation
propriedades idênticas às de LinearGradient.
center
instância de Alignment. O centro do gradiente em relação ao objeto que recebe o gradiente. Por exemplo, alinhamento de (0.0, 0.0) coloca o centro do gradiente radial no centro da caixa.
radius
raio do gradiente, dado como fração do lado mais curto da caixa. Supondo uma caixa com largura = 100 e altura = 200 pixeis, um raio de 1 no gradiente radial colocará uma parada de 1,0 afastado 100,0 pixeis do centro.
focal
ponto focal do gradiente. Se especificado, o gradiente parecerá focado ao longo do vetor do centro até esse ponto focal.
focal_radius
raio do ponto focal do gradiente, dado como fração do lado mais curto da caixa. Ex.: um gradiente radial desenhado sobre uma caixa com largura = 100,0 e altura = 200,0 (pixeis), um raio de 1,0 colocará uma parada de 1,0 a 100,0 pixels do ponto focal.
São propriedades da classe SweepGradient:
colors, stops, tile_mode, rotation
propriedades idênticas às de LinearGradient.
center
centro do gradiente em relação ao objeto que recebe o gradiente. Por exemplo, alinhamento de (0.0, 0.0) coloca o centro do gradiente no centro da caixa.
start_angle
ângulo em radianos onde será colocada a parada 0.0 do gradiente. Default: 0.0.
end_angle
ângulo em radianos onde será colocada a parada 1.0 do gradiente. Default: math.pi * 2.
Graus e radianos
A maiora das medidas angulares na programação do flet (e do python em geral) é dada em radianos. Segue uma breve imagem explicativa do uso de radianos.