PR

[Flutter]Flutter Widget of the Week「#106 html」、「#107 RefreshIndicator」、「#108 font_awesome_flutter」

Flutter

はじめに

前回はFlutter Widget of the Weekの「#103 sensors_plus」、「#104 collection」、「#105 HeroMode」を紹介しました。

今回はその続きで「#106 html」、「#107 RefreshIndicator」、「#108 font_awesome_flutter」の3つです。

前回の記事はこちら

またGitHubにも公開しています。

GitHub - nobushiueshi/flutter_widget_of_the_week
Contribute to nobushiueshi/flutter_widget_of_the_week development by creating an account on GitHub.

Flutter Widget of the Week

環境

  • Flutter 3.3.8

記事にした時点でのバージョンです。GitHubに公開しているのは常に最新の安定版(stable)を使う予定です。

#106 html

htmlとは

HTML5のパーサーで、HTMLドキュメントを作成するオブジェクトを作ることができます。

サンプルコード

import 'package:flutter/material.dart';
import 'package:html/parser.dart';

class SamplePage106 extends StatelessWidget {
  const SamplePage106({
    super.key,
  });

  String get myHtml => '<body><div id="dash"><p>Hello</p></body>';

  @override
  Widget build(BuildContext context) {
    final document = parse(myHtml);
    return Scaffold(
      appBar: AppBar(
        title: const Text('html'),
        centerTitle: true,
      ),
      body: SafeArea(
        child: Center(
          child: Column(
            mainAxisSize: MainAxisSize.min,
            children: [
              const Text('document.outerHtml:'),
              Text(document.outerHtml),
              const SizedBox(height: 20),
              const Text('document.getElementById:'),
              Text(document.getElementById('dash')?.innerHtml ?? ''),
              const SizedBox(height: 20),
              const Text('document.querySelectorAll:'),
              Text(document.querySelectorAll('div > p')[0].innerHtml),
              const SizedBox(height: 20),
            ],
          ),
        ),
      ),
    );
  }
}

結果

動画

公式リファレンス

html | Dart package
APIs for parsing and manipulating HTML content outside the browser.

#107 RefreshIndicator

RefreshIndicatorとは

リストをスワイプで更新する際に、更新中を表示することができるウィジェットです。

サンプルコード

import 'package:flutter/material.dart';

class SamplePage107 extends StatefulWidget {
  const SamplePage107({
    super.key,
  });

  @override
  State<SamplePage107> createState() => _SamplePage107State();
}

class _SamplePage107State extends State<SamplePage107> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('RefreshIndicator'),
        centerTitle: true,
      ),
      body: SafeArea(
        child: RefreshIndicator(
          onRefresh: () async {
            await Future<void>.delayed(const Duration(seconds: 2));
          },
          child: ListView.builder(
            itemCount: 30,
            itemBuilder: (context, index) {
              return ListTile(
                title: Text('index : $index'),
              );
            },
          ),
        ),
      ),
    );
  }
}

結果

動画

公式リファレンス

RefreshIndicator class - material library - Dart API
API docs for the RefreshIndicator class from the material library, for the Dart programming language.

#108 font_awesome_flutter

font_awesome_flutterとは

優れたアイコンセットが多く入ったパッケージです。

サンプルコード

import 'package:flutter/material.dart';
import 'package:font_awesome_flutter/font_awesome_flutter.dart';

class SamplePage108 extends StatelessWidget {
  const SamplePage108({super.key});

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('font_awesome_flutter'),
        centerTitle: true,
      ),
      body: SafeArea(
        child: Center(
          child: Column(
            mainAxisAlignment: MainAxisAlignment.center,
            children: const [
              FaIcon(FontAwesomeIcons.google),
              SizedBox(height: 20),
              FaIcon(FontAwesomeIcons.apple),
              SizedBox(height: 20),
              FaIcon(FontAwesomeIcons.meta),
              SizedBox(height: 20),
              FaIcon(FontAwesomeIcons.amazon),
              SizedBox(height: 20),
              FaIcon(FontAwesomeIcons.microsoft),
            ],
          ),
        ),
      ),
    );
  }
}

結果

動画

公式リファレンス

font_awesome_flutter | Flutter package
The Font Awesome Icon pack available as Flutter Icons. Provides 2000 additional icons to use in your apps.

さいごに

このシリーズ、終りが見えない。。。

そして追いつく前にYouTubeのFlutter Widget of the Weekが終わってしまい、悲しみ。

おすすめ参考書

リンク

GitHub - nobushiueshi/flutter_widget_of_the_week
Contribute to nobushiueshi/flutter_widget_of_the_week development by creating an account on GitHub.

コメント

タイトルとURLをコピーしました