成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

花里胡哨,如何在 Flutter 中制作多種顏色的 TextField

開發(fā) 前端
TextField? 將其樣式傳遞給 TextEditingController? ,默認實現(xiàn)只是將其放入 TextSpan 對象中,這就是通常應(yīng)用顏色的方式。

TextField widget 本身并不施加任何樣式。相反,它會要求 TextEditingController 生成一個樣式化的 TextSpan 對象,即一段帶有樣式的文本。

圖片圖片

TextField 將其樣式傳遞給 TextEditingController ,默認實現(xiàn)只是將其放入 TextSpan 對象中,這就是通常應(yīng)用顏色的方式。

要重載該方法,請子類化 TextEditingController 并重載該方法:

class GradientTextEditingController extends TextEditingController {
  @override
  TextSpan buildTextSpan({
    required BuildContext context,
    TextStyle? style,
    bool? withComposing,
  }) {
    style ??= const TextStyle();
    final leftStyle = style.copyWith(color: Colors.red);
    final rightStyle = style.copyWith(color: Colors.indigo);
    final children = <TextSpan>[];

    for (final char in text.characters) {
      children.add(
        TextSpan(
          text: char,
          style: TextStyle.lerp(
            leftStyle,
            rightStyle,
            children.length / text.length,
          ),
        ),
      );
    }

    return TextSpan(style: style, children: children);
  }
}

圖片圖片

請參閱此處的完整代碼。

https://gist.github.com/alexeyinkin/ee65ed81913c8962c2d19e28e11cb262

你可以進行更復(fù)雜的處理。例如,我們通過解析語法樹并對關(guān)鍵字、字面量、注釋等進行不同的著色,來制作代碼高亮:

圖片圖片

我們首先導(dǎo)入為另一個項目制作的 highlighting 和 flutter_highlighting 包:

import 'package:flutter_highlighting/themes/vs.dart';
import 'package:highlighting/highlighting.dart';
import 'package:highlighting/languages/java.dart';

然后我們解析文本并得到語法樹的簡單形式:

class SyntaxTextEditingController extends TextEditingController {
  @override
  TextSpan buildTextSpan({
    required BuildContext context,
    TextStyle? style,
    bool? withComposing,
  }) {
    final highlighted = highlight.parse(text, languageId: java.id);

    return TextSpan(
      style: style,
      children: _buildList(
        nodes: highlighted.nodes,
        styles: vsTheme, // Built-in theme from flutter_highlighting
        ancestorStyle: style,
      ),
    );
  }
  // ...

接下來是遍歷語法樹并為每個節(jié)點返回 TextSpan :

List<TextSpan>? _buildList({
    required List<Node>? nodes,
    required Map<String, TextStyle> styles,
    TextStyle? ancestorStyle,
  }) {
    return nodes
        ?.map(
          (node) => _buildNode(
            node: node,
            styles: styles,
            ancestorStyle: ancestorStyle,
          ),
        )
        .toList(growable: false);
  }

  TextSpan _buildNode({
    required Node node,
    required Map<String, TextStyle> styles,
    TextStyle? ancestorStyle,
  }) {
    final style = styles[node.className] ?? ancestorStyle;

    return TextSpan(
      text: node.value,
      children: _buildList(
        nodes: node.children,
        styles: styles,
        ancestorStyle: style,
      ),
      style: style,
    );
  }

請參閱此處的完整代碼。

https://gist.github.com/alexeyinkin/bff79a057cbf04ecd5166243d06f1d44

因此,TextEditingController 類是實現(xiàn)各種自定義功能的大門。我們在這條路上走得更遠,并制作了一個可以做到這一點的高級代碼編輯器:

圖片圖片

如果您有興趣,請查看這里。

https://medium.com/akvelon/flutter-code-editor-19e0090a62cc

原文:https://medium.com/akvelon/how-to-make-textfield-in-multiple-colors-in-flutter-c317ae0efafe

責(zé)任編輯:武曉燕 來源: 獨立開發(fā)者張張
相關(guān)推薦

2017-03-09 19:32:22

LinuxWindowsUSB

2022-09-22 06:53:02

FreeDOSLinux

2020-06-08 11:50:38

GIMPGIF應(yīng)用

2022-05-31 08:49:02

Flutter應(yīng)用程序前端

2022-02-23 16:56:43

Python多渠道歸因模型數(shù)據(jù)驅(qū)動

2020-06-30 08:55:29

Vim文本編輯器Linux

2023-06-07 10:41:43

2020-06-15 18:40:15

Ubuntu 20.0文件夾顏色Ubuntu

2009-10-21 17:03:05

VB實例教程

2018-02-24 16:30:49

LinuxUnixBash

2012-09-28 10:31:42

微軟LogoWindows

2017-10-22 16:10:08

windows 10顏色篩選器系統(tǒng)

2011-08-09 15:25:00

Windows7

2024-07-11 11:40:23

Flutter2D視圖

2021-12-06 16:20:38

Flutter開發(fā)Linux

2012-09-28 10:45:33

微軟Logo

2023-06-21 14:47:47

Bash

2011-05-31 15:56:52

游戲啟動菜單Android

2022-11-22 08:24:28

UbuntuLinux命令

2020-07-01 18:31:14

Linuxbash永遠循環(huán)
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 日韩二区三区 | 中文字幕免费在线 | 99精品电影| 久草在线在线精品观看 | 正在播放国产精品 | 欧美视频福利 | 蜜臀久久99精品久久久久野外 | 最新国产福利在线 | 女人精96xxx免费网站p | 波多野结衣一区二区三区 | 自拍视频网 | 在线一区二区三区 | 午夜影视| 欧洲一级视频 | av电影手机版| 国产亚洲精品精品国产亚洲综合 | 精品一区二区久久 | 亚洲精品一区在线 | 中国人pornoxxx麻豆 | 不卡一二三区 | 精品综合 | 色综合久 | 精品久久久久久久久久 | 在线国产一区二区 | 国产99免费| 免费播放一级片 | 欧州一区二区三区 | 午夜寂寞影院在线观看 | 欧美男人天堂 | 九色.com| 欧美日韩一卡 | 国产精品一区二区在线 | 国产精品久久久久久久免费大片 | 国产激情视频网站 | 99精品视频在线观看 | 一区二区三区在线观看免费视频 | 日韩成人免费 | 狠狠爱一区二区三区 | 日韩一区欧美一区 | 99久久精品免费看国产四区 | 老司机精品福利视频 |