Flutter 实现酷炫的3D效果

移动开发 作者: 2024-08-24 21:30:02
老孟导读:此文讲解3个酷炫的3D动画效果。 下面是要实现的效果: Flutter 中3D效果是通过 Transform 组件实现的,没有变换效果的实现: class TransformDemo ext
class TransformDemo extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('3D 变换Demo'),),body: Container(
        alignment: Alignment.center,color: Colors.white,child: Text('3D 变换Demo'),);
  }
}
@override
Widget build(BuildContext context) {
  return Scaffold(
    appBar: AppBar(
      title: Text('3D 变换Demo'),body: GestureDetector(
      onPanUpdate: (details) {
        print('$details');
      },child: Container(
        alignment: Alignment.center,);
}
@override
Widget build(BuildContext context) {
  return Transform(
      transform: Matrix4.identity()
        ..setEntry(3,2,0.001)
        ..rotateX(pi/6)
        ..rotateY(pi/6),alignment: Alignment.center,child: Scaffold(
        appBar: AppBar(
          title: Text('3D 变换Demo'),body: GestureDetector(
          onPanUpdate: (details) {
          },child: Container(
            alignment: Alignment.center,));
}
class TransformDemo extends StatefulWidget {
  @override
  _TransformDemoState createState() => _TransformDemoState();
}

class _TransformDemoState extends State<TransformDemo> {
  double _rotateX = .0;
  double _rotateY = .0;

  @override
  Widget build(BuildContext context) {
    return Transform(
        transform: Matrix4.identity()
          ..rotateX(_rotateX)
          ..rotateY(_rotateY),child: Scaffold(
          appBar: AppBar(
            title: Text('3D 变换Demo'),body: GestureDetector(
            onPanUpdate: (details) {
              setState(() {
                _rotateX += details.delta.dy * .01;
                _rotateY += details.delta.dx * -.01;
              });
            },child: Container(
              alignment: Alignment.center,));
  }
}
Transform(
    transform: Matrix4.identity()
      ..setEntry(3,0.001)
      ..rotateX(_rotateX)
      ..rotateY(_rotateY),...

翻书效果

_child1 = ClipRect(
  child: Align(
    alignment: Alignment.centerLeft,widthFactor: 0.5,child: child1,);
_child2 = ClipRect(
  child: Align(
    alignment: Alignment.centerRight,);

_child3 = ClipRect(
  child: Align(
    alignment: Alignment.centerLeft,child: child2,);

_child4 = ClipRect(
  child: Align(
    alignment: Alignment.centerRight,);
Row(
  mainAxisAlignment: MainAxisAlignment.center,children: <Widget>[
    Stack(
      children: [
        _child1,Transform(
          alignment: Alignment.centerRight,transform: Matrix4.identity()
            ..setEntry(3,0.001)
            ..rotateY(_animation1.value),child: _child3,],Container(
      width: 3,Stack(
      children: [
        _child4,Transform(
          alignment: Alignment.centerLeft,0.001)
            ..rotateY(_animation.value),child: _child2,)
      ],)
  ],)
@override
void initState() {
  init();
  _controller =
      AnimationController(vsync: this,duration: Duration(seconds: 5))
        ..addListener(() {
          setState(() {});
        });
  _animation = Tween(begin: .0,end: pi / 2)
      .animate(CurvedAnimation(parent: _controller,curve: Interval(.0,.5)));
  _animation1 = Tween(begin: -pi / 2,end: 0.0).animate(
      CurvedAnimation(parent: _controller,curve: Interval(.5,1.0)));
  _controller.forward();
  super.initState();
}
_FlipUpDemoState(
    Container(
      width: 300,height: 400,child: Image.asset(
        'assets/images/b.jpg',fit: BoxFit.cover,Container(
      width: 300,child: Image.asset(
        'assets/images/c.jpeg',))
@override
Widget build(BuildContext context) {
  return Scaffold(
    appBar: AppBar(),body: Column(
      mainAxisAlignment: MainAxisAlignment.center,children: <Widget>[
        Stack(
          children: [
            _upperChild1,Transform(
              alignment: Alignment.bottomCenter,transform: Matrix4.identity()
                ..setEntry(3,0.003)
                ..rotateX(_animation1.value),child: _upperChild2,SizedBox(
          height: 2,Stack(
          children: [
            _lowerChild2,Transform(
              alignment: Alignment.topCenter,0.003)
                ..rotateX(_animation.value),child: _lowerChild1,)
          ],);
}
原创声明
本站部分文章基于互联网的整理,我们会把真正“有用/优质”的文章整理提供给各位开发者。本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
本文链接:http://www.jiecseo.com/news/show_68033.html