Skip to content

Instantly share code, notes, and snippets.

@rashmisridar
Last active April 29, 2020 14:19
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save rashmisridar/9a3606684fdc79fa98a0dbe8199d9881 to your computer and use it in GitHub Desktop.
Save rashmisridar/9a3606684fdc79fa98a0dbe8199d9881 to your computer and use it in GitHub Desktop.
Need to dismiss DraggableScrollableSheet
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:flutter/rendering.dart';
void main() => runApp(MaterialApp(
theme: ThemeData(
canvasColor: Colors.black,
primaryColor: Colors.blue,
backgroundColor: Colors.black,
),
home: Scaffold(body: DraggableScrollDismiss())));
class DraggableScrollDismiss extends StatefulWidget {
@override
_MainScreenState createState() => _MainScreenState();
}
BuildContext mDragableContext;
final PageController mPageCtrller = PageController();
//when scroll up then
bool btnClicked = false;
double mNotificationExtenedValue = 0.0;
List<String> _featureList = List();
class _MainScreenState extends State<DraggableScrollDismiss>
with TickerProviderStateMixin {
@override
void initState() {
super.initState();
_featureList.add("A");
_featureList.add("B");
_featureList.add("C");
_featureList.add("D");
_featureList.add("E");
_featureList.add("F");
}
@override
void dispose() {
super.dispose();
}
@override
Widget build(BuildContext context) {
return Scaffold(
resizeToAvoidBottomInset: false,
resizeToAvoidBottomPadding: false,
appBar: AppBar(
title: Text("Practice"),
),
body: displayData(),
);
}
}
Widget displayData() {
return Column(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Expanded(
flex: 3,
child: Stack(
children: <Widget>[
Container(
margin: EdgeInsets.fromLTRB(5, 30, 0, 0),
child: AspectRatio(
aspectRatio: 5 / 4,
child: InkWell(
focusColor: Colors.transparent,
highlightColor: Colors.transparent,
splashColor: Colors.grey,
child: Align(
alignment: Alignment.centerRight,
child: new Image.network(
"",
fit: BoxFit.cover,
),
),
),
),
),
Container(
child: SizedBox.expand(
child: NotificationListener<DraggableScrollableNotification>(
onNotification: (notification) {},
child: DraggableScrollableSheet(
initialChildSize: 0.30, //0.50,
minChildSize: 0.30, //0.50,
maxChildSize: 1.0, //1.0,
builder: (BuildContext context,
ScrollController scrollController) {
return ListView.builder(
controller: scrollController,
itemCount: 1,
itemBuilder: (BuildContext context, int index) {
return Container(
child: Column(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Container(
margin: EdgeInsets.fromLTRB(20, 0, 0, 0),
child: Column(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
SizedBox(
height: 40,
),
Column(
mainAxisAlignment:
MainAxisAlignment.start,
crossAxisAlignment:
CrossAxisAlignment.start,
children: <Widget>[
Container(
child: Text(
"Nature1",
style: TextStyle(
fontSize: 16.0,
color: Colors.white,
fontWeight: FontWeight.w400),
),
),
SizedBox(
height: 15,
),
Container(
child: Text("simply dummy text",
style: TextStyle(
fontSize: 16.0,
color: Colors.white,
fontWeight:
FontWeight.w400))),
SizedBox(
height: 15,
),
Container(
child: Text(
"simply dummy text",
style: TextStyle(
fontSize: 16.0,
color: Colors.white,
fontWeight: FontWeight.w400),
),
),
],
),
Align(
alignment: Alignment.bottomCenter,
child: Container(
width: 30,
height: 70,
decoration: BoxDecoration(
color: Colors.grey,
shape: BoxShape.circle,
),
child: Icon(
btnClicked
? Icons.keyboard_arrow_down
: Icons.keyboard_arrow_up,
color: Colors.black,
), //Icon(Icons.person),
),
),
Padding(
padding: const EdgeInsets.fromLTRB(
15, 0, 15, 0),
child: GridView.count(
childAspectRatio: 5 / 1.5,
physics: BouncingScrollPhysics(),
shrinkWrap: true,
crossAxisCount: 2,
crossAxisSpacing: 1.5,
mainAxisSpacing: 15,
//space between the child
// Create a grid with 2 columns. If you change the scrollDirection to
// horizontal, this produces 2 rows.
children: List.generate(
_featureList.length,
(index) {
return Row(
children: <Widget>[
Expanded(
child: Text(
'${_featureList[index]}',
overflow:
TextOverflow.ellipsis,
style: TextStyle(
color: Colors.grey,
fontSize: 12),
maxLines: 1,
textAlign:
TextAlign.start,
),
)
],
);
},
)),
),
],
),
)
]));
},
);
},
),
),
))
],
),
),
],
);
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment