首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >颤振涡旋在滑块中不起作用

颤振涡旋在滑块中不起作用
EN

Stack Overflow用户
提问于 2020-07-16 19:57:01
回答 1查看 708关注 0票数 0

我有一个按钮,当点击它退出显示对话框,其中有一个滑块(slider_pro -包)。我是通过json得到照片的。照片出来的很好,但水平滚动不起作用。如何将其放入显示对话框- slider_pro中,并将导航放在那里。提前谢谢你。您可以在我的代码中看到更多细节,请按照链接进行操作。https://github.com/akbarsulaymonov/Slider_ShowDialog/blob/master/1

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-07-17 02:21:42

您可以复制粘贴,运行下面的完整代码

您可以使用List<Widget>.generateInkWell

代码段

代码语言:javascript
复制
images: List<Widget>.generate(
          data.length,
          (index) => InkWell(
            onTap: () {
              Navigator.push(
                context,
                MaterialPageRoute(
                    builder: (context) => SecondRoute(
                        url: data[index]["url"])),
              );
            },
            child: CachedNetworkImage(
                imageUrl: data[index]["url"],

工作演示

全码

代码语言:javascript
复制
import 'package:cached_network_image/cached_network_image.dart';
import 'package:carousel_pro/carousel_pro.dart';
import 'package:flutter/material.dart';

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

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
        visualDensity: VisualDensity.adaptivePlatformDensity,
      ),
      home: MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key key, this.title}) : super(key: key);

  final String title;

  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  List<Map> data = [
    {"url": 'https://picsum.photos/250?image=9'},
    {"url": 'https://picsum.photos/250?image=10'},
    {"url": 'https://picsum.photos/250?image=11'},
  ];

  void showSimpleCustomDialog(BuildContext context, data) {
    Dialog simpleDialog = Dialog(
        shape: RoundedRectangleBorder(
          borderRadius: BorderRadius.circular(5.0),
        ),
        child: Container(
            margin: EdgeInsets.symmetric(
              vertical: 10.0,
            ),
            height: 150.0,
            decoration: BoxDecoration(
                //color:Hexcolor('#205CBE'),
                ),
            child: data.length > 0
                ? Center(
                  child: SizedBox(
                    height: 150.0,
                    width: 300.0,
                    child: Carousel(
                        boxFit: BoxFit.cover,
                        autoplay: false,
                        animationCurve: Curves.fastOutSlowIn,
                        animationDuration: Duration(milliseconds: 1000),
                        dotSize: 6.0,
                        dotIncreasedColor: Color(0xFFFF335C),
                        dotBgColor: Colors.transparent,
                        dotPosition: DotPosition.bottomCenter,
                        dotVerticalPadding: 10.0,
                        showIndicator: true,
                        indicatorBgPadding: 7.0,
                        images: List<Widget>.generate(
                          data.length,
                          (index) => InkWell(
                            onTap: () {
                              Navigator.push(
                                context,
                                MaterialPageRoute(
                                    builder: (context) => SecondRoute(
                                        url: data[index]["url"])),
                              );
                            },
                            child: CachedNetworkImage(
                                imageUrl: data[index]["url"],
                                height: 150.0,
                                width: 300,
                                placeholder: (BuildContext context,
                                        String url) =>
                                    Container(
                                        width: 300.0,
                                        height: 150.0,
                                        child: Center(
                                            child:
                                                CircularProgressIndicator()))),
                          ),
                        )),
                  ),
                )
                : Text("Фото недоступна")));

    showDialog(
        context: context, builder: (BuildContext context) => simpleDialog);
  }

  int _counter = 0;

  void _incrementCounter() {
    setState(() {
      _counter++;
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text(widget.title),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            RaisedButton(
              onPressed: () {
                showSimpleCustomDialog(context, data);
              },
              child: Text("click"),
            ),
            Text(
              'You have pushed the button this many times:',
            ),
            Text(
              '$_counter',
              style: Theme.of(context).textTheme.headline4,
            ),
          ],
        ),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: _incrementCounter,
        tooltip: 'Increment',
        child: Icon(Icons.add),
      ),
    );
  }
}

class SecondRoute extends StatelessWidget {
  final String url;
  SecondRoute({this.url});

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("$url"),
      ),
      body: Center(
        child: RaisedButton(
          onPressed: () {
            // Navigate back to first route when tapped.
          },
          child: Text('Go back!'),
        ),
      ),
    );
  }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62942547

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档