animated_line_through 1.0.5 copy "animated_line_through: ^1.0.5" to clipboard
animated_line_through: ^1.0.5 copied to clipboard

Animated line through for text for Flutter, with full control over animation

example/lib/main.dart

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

void main() {
  runApp(const MyApp());
}

const _lorum =
    "Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.";
const _lorumAr =
    "هناك حقيقة مثبتة منذ زمن طويل وهي أن المحتوى المقروء لصفحة ما سيلهي القارئ عن التركيز على الشكل الخارجي للنص أو شكل توضع الفقرات في الصفحة التي يقرأها.";
const _lorumArShort = "لوريم إيبسوم";

enum _Tabs {
  simple,
  raw;
}

extension on _Tabs {
  String get format {
    switch (this) {
      case _Tabs.simple:
        return 'Simple';
      case _Tabs.raw:
        return 'Raw';
    }
  }

  Widget get tabView {
    switch (this) {
      case _Tabs.simple:
        return const _Simple();
      case _Tabs.raw:
        return const _Raw();
    }
  }
}

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

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
        useMaterial3: true,
      ),
      home: DefaultTabController(
        length: _Tabs.values.length,
        child: const _Screen(),
      ),
    );
  }
}

class _Screen extends StatelessWidget {
  const _Screen();

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('Animated Line Through'),
        bottom: TabBar(
          controller: DefaultTabController.of(context),
          tabs: [
            for (final tab in _Tabs.values)
              Tab(
                child: Text(tab.format),
              ),
          ],
        ),
      ),
      body: const _Body(),
    );
  }
}

class _Body extends StatelessWidget {
  const _Body();

  @override
  Widget build(BuildContext context) {
    return Padding(
      padding: const EdgeInsets.symmetric(
        horizontal: 16,
        vertical: 24,
      ),
      child: TabBarView(
        children: [for (final tab in _Tabs.values) tab.tabView],
      ),
    );
  }
}

class _Simple extends StatefulWidget {
  const _Simple();

  @override
  State<_Simple> createState() => _SimpleState();
}

class _SimpleState extends State<_Simple> {
  bool _isCrossed = false;

  @override
  Widget build(BuildContext context) {
    return Column(
      children: [
        SwitchListTile.adaptive(
          value: _isCrossed,
          onChanged: (isCrossed) => setState(() {
            _isCrossed = isCrossed;
          }),
          title: const Text('Cross line'),
        ),
        const Divider(),
        AnimatedLineThrough(
          duration: const Duration(milliseconds: 500),
          isCrossed: _isCrossed,
          child: TextFormField(
            initialValue: _lorum,
            maxLines: null,
          ),
        ),
        const Divider(height: 32),
        Directionality(
          textDirection: TextDirection.rtl,
          child: Column(
            crossAxisAlignment: CrossAxisAlignment.start,
            children: [
              AnimatedLineThrough(
                duration: const Duration(milliseconds: 500),
                isCrossed: _isCrossed,
                child: const Text(_lorumAr),
              ),
              const Divider(),
              AnimatedLineThrough(
                duration: const Duration(milliseconds: 500),
                isCrossed: _isCrossed,
                child: const Text(_lorumArShort),
              ),
            ],
          ),
        )
      ],
    );
  }
}

class _Raw extends StatefulWidget {
  const _Raw();

  @override
  State<_Raw> createState() => _RawState();
}

class _RawState extends State<_Raw> with SingleTickerProviderStateMixin {
  late final AnimationController _controller = AnimationController(vsync: this);

  @override
  Widget build(BuildContext context) {
    return Column(
      children: [
        const Text('Crossed value:'),
        Slider.adaptive(
          value: _controller.value,
          min: 0.0,
          max: 1.0,
          onChanged: (value) => setState(() {
            _controller.value = value;
          }),
        ),
        const Divider(),
        AnimatedLineThroughRaw(
          crossed: _controller,
          color: Colors.black,
          child: const Text(_lorum),
        ),
      ],
    );
  }
}
23
likes
150
points
325
downloads

Publisher

unverified uploader

Weekly Downloads

Animated line through for text for Flutter, with full control over animation

Repository (GitHub)
View/report issues

Documentation

API reference

License

BSD-3-Clause (license)

Dependencies

flutter

More

Packages that depend on animated_line_through