Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
68c77e37
Unverified
Commit
68c77e37
authored
Apr 04, 2018
by
David Shuckerow
Committed by
GitHub
Apr 04, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add a bottom app bar to the floating action button motion demo. (#16196)
parent
b8629bab
Changes
5
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
510 additions
and
157 deletions
+510
-157
bottom_app_bar_demo.dart
...lutter_gallery/lib/demo/material/bottom_app_bar_demo.dart
+500
-0
fab_motion_demo.dart
...es/flutter_gallery/lib/demo/material/fab_motion_demo.dart
+0
-147
material.dart
examples/flutter_gallery/lib/demo/material/material.dart
+1
-1
item.dart
examples/flutter_gallery/lib/gallery/item.dart
+7
-7
floating_action_button_location.dart
...ter/lib/src/material/floating_action_button_location.dart
+2
-2
No files found.
examples/flutter_gallery/lib/demo/material/bottom_app_bar_demo.dart
0 → 100644
View file @
68c77e37
This diff is collapsed.
Click to expand it.
examples/flutter_gallery/lib/demo/material/fab_motion_demo.dart
deleted
100644 → 0
View file @
b8629bab
// Copyright 2018 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import
'package:flutter/material.dart'
;
const
String
_explanatoryText
=
"When the Scaffold's floating action button location changes, "
'the floating action button animates to its new position'
;
class
FabMotionDemo
extends
StatefulWidget
{
static
const
String
routeName
=
'/material/fab-motion'
;
@override
_FabMotionDemoState
createState
()
{
return
new
_FabMotionDemoState
();
}
}
class
_FabMotionDemoState
extends
State
<
FabMotionDemo
>
{
static
const
List
<
FloatingActionButtonLocation
>
_floatingActionButtonLocations
=
const
<
FloatingActionButtonLocation
>[
FloatingActionButtonLocation
.
endFloat
,
FloatingActionButtonLocation
.
centerFloat
,
const
_StartTopFloatingActionButtonLocation
(),
];
bool
_showFab
=
true
;
FloatingActionButtonLocation
_floatingActionButtonLocation
=
FloatingActionButtonLocation
.
endFloat
;
@override
Widget
build
(
BuildContext
context
)
{
final
Widget
floatingActionButton
=
_showFab
?
new
Builder
(
builder:
(
BuildContext
context
)
{
// We use a widget builder here so that this inner context can find the Scaffold.
// This makes it possible to show the snackbar.
return
new
FloatingActionButton
(
backgroundColor:
Colors
.
yellow
.
shade900
,
onPressed:
()
=>
_showSnackbar
(
context
),
child:
const
Icon
(
Icons
.
add
),
);
})
:
null
;
return
new
Scaffold
(
appBar:
new
AppBar
(
title:
const
Text
(
'FAB Location'
),
// Add 48dp of space onto the bottom of the appbar.
// This gives space for the top-start location to attach to without
// blocking the 'back' button.
bottom:
const
PreferredSize
(
preferredSize:
const
Size
.
fromHeight
(
48.0
),
child:
const
SizedBox
(),
),
),
floatingActionButtonLocation:
_floatingActionButtonLocation
,
floatingActionButton:
floatingActionButton
,
body:
new
Center
(
child:
new
Column
(
mainAxisAlignment:
MainAxisAlignment
.
center
,
children:
<
Widget
>[
new
RaisedButton
(
onPressed:
_moveFab
,
child:
const
Text
(
'MOVE FAB'
),
),
new
Row
(
mainAxisAlignment:
MainAxisAlignment
.
center
,
children:
<
Widget
>[
const
Text
(
'Toggle FAB'
),
new
Switch
(
value:
_showFab
,
onChanged:
_toggleFab
),
],
),
],
),
),
);
}
void
_moveFab
()
{
setState
(()
{
_floatingActionButtonLocation
=
_floatingActionButtonLocations
[(
_floatingActionButtonLocations
.
indexOf
(
_floatingActionButtonLocation
)
+
1
)
%
_floatingActionButtonLocations
.
length
];
});
}
void
_toggleFab
(
bool
showFab
)
{
setState
(()
{
_showFab
=
showFab
;
});
}
void
_showSnackbar
(
BuildContext
context
)
{
Scaffold
.
of
(
context
).
showSnackBar
(
const
SnackBar
(
content:
const
Text
(
_explanatoryText
)));
}
}
// Places the Floating Action Button at the top of the content area of the
// app, on the border between the body and the app bar.
class
_StartTopFloatingActionButtonLocation
extends
FloatingActionButtonLocation
{
const
_StartTopFloatingActionButtonLocation
();
@override
Offset
getOffset
(
ScaffoldPrelayoutGeometry
scaffoldGeometry
)
{
// First, we'll place the X coordinate for the Floating Action Button
// at the start of the screen, based on the text direction.
double
fabX
;
assert
(
scaffoldGeometry
.
textDirection
!=
null
);
switch
(
scaffoldGeometry
.
textDirection
)
{
case
TextDirection
.
rtl
:
// In RTL layouts, the start of the screen is on the right side,
// and the end of the screen is on the left.
//
// We need to align the right edge of the floating action button with
// the right edge of the screen, then move it inwards by the designated padding.
//
// The Scaffold's origin is at its top-left, so we need to offset fabX
// by the Scaffold's width to get the right edge of the screen.
//
// The Floating Action Button's origin is at its top-left, so we also need
// to subtract the Floating Action Button's width to align the right edge
// of the Floating Action Button instead of the left edge.
final
double
startPadding
=
kFloatingActionButtonMargin
+
scaffoldGeometry
.
minInsets
.
right
;
fabX
=
scaffoldGeometry
.
scaffoldSize
.
width
-
scaffoldGeometry
.
floatingActionButtonSize
.
width
-
startPadding
;
break
;
case
TextDirection
.
ltr
:
// In LTR layouts, the start of the screen is on the left side,
// and the end of the screen is on the right.
//
// Placing the fabX at 0.0 will align the left edge of the
// Floating Action Button with the left edge of the screen, so all
// we need to do is offset fabX by the designated padding.
final
double
startPadding
=
kFloatingActionButtonMargin
+
scaffoldGeometry
.
minInsets
.
left
;
fabX
=
startPadding
;
break
;
}
// Finally, we'll place the Y coordinate for the Floating Action Button
// at the top of the content body.
//
// We want to place the middle of the Floating Action Button on the
// border between the Scaffold's app bar and its body. To do this,
// we place fabY at the scaffold geometry's contentTop, then subtract
// half of the Floating Action Button's height to place the center
// over the contentTop.
//
// We don't have to worry about which way is the top like we did
// for left and right, so we place fabY in this one-liner.
final
double
fabY
=
scaffoldGeometry
.
contentTop
-
(
scaffoldGeometry
.
floatingActionButtonSize
.
height
/
2.0
);
return
new
Offset
(
fabX
,
fabY
);
}
}
examples/flutter_gallery/lib/demo/material/material.dart
View file @
68c77e37
...
@@ -3,6 +3,7 @@
...
@@ -3,6 +3,7 @@
// found in the LICENSE file.
// found in the LICENSE file.
export
'backdrop_demo.dart'
;
export
'backdrop_demo.dart'
;
export
'bottom_app_bar_demo.dart'
;
export
'bottom_navigation_demo.dart'
;
export
'bottom_navigation_demo.dart'
;
export
'buttons_demo.dart'
;
export
'buttons_demo.dart'
;
export
'cards_demo.dart'
;
export
'cards_demo.dart'
;
...
@@ -12,7 +13,6 @@ export 'date_and_time_picker_demo.dart';
...
@@ -12,7 +13,6 @@ export 'date_and_time_picker_demo.dart';
export
'dialog_demo.dart'
;
export
'dialog_demo.dart'
;
export
'drawer_demo.dart'
;
export
'drawer_demo.dart'
;
export
'expansion_panels_demo.dart'
;
export
'expansion_panels_demo.dart'
;
export
'fab_motion_demo.dart'
;
export
'grid_list_demo.dart'
;
export
'grid_list_demo.dart'
;
export
'icons_demo.dart'
;
export
'icons_demo.dart'
;
export
'leave_behind_demo.dart'
;
export
'leave_behind_demo.dart'
;
...
...
examples/flutter_gallery/lib/gallery/item.dart
View file @
68c77e37
...
@@ -88,6 +88,13 @@ List<GalleryItem> _buildGalleryItems() {
...
@@ -88,6 +88,13 @@ List<GalleryItem> _buildGalleryItems() {
routeName:
BackdropDemo
.
routeName
,
routeName:
BackdropDemo
.
routeName
,
buildRoute:
(
BuildContext
context
)
=>
new
BackdropDemo
(),
buildRoute:
(
BuildContext
context
)
=>
new
BackdropDemo
(),
),
),
new
GalleryItem
(
title:
'Bottom App Bar'
,
subtitle:
'With repositionable floating action button'
,
category:
'Material Components'
,
routeName:
BottomAppBarDemo
.
routeName
,
buildRoute:
(
BuildContext
context
)
=>
new
BottomAppBarDemo
(),
),
new
GalleryItem
(
new
GalleryItem
(
title:
'Bottom navigation'
,
title:
'Bottom navigation'
,
subtitle:
'Bottom navigation with cross-fading views'
,
subtitle:
'Bottom navigation with cross-fading views'
,
...
@@ -165,13 +172,6 @@ List<GalleryItem> _buildGalleryItems() {
...
@@ -165,13 +172,6 @@ List<GalleryItem> _buildGalleryItems() {
routeName:
TabsFabDemo
.
routeName
,
routeName:
TabsFabDemo
.
routeName
,
buildRoute:
(
BuildContext
context
)
=>
new
TabsFabDemo
(),
buildRoute:
(
BuildContext
context
)
=>
new
TabsFabDemo
(),
),
),
new
GalleryItem
(
title:
'Floating action button motion'
,
subtitle:
'Action buttons with customized positions'
,
category:
'Material Components'
,
routeName:
FabMotionDemo
.
routeName
,
buildRoute:
(
BuildContext
context
)
=>
new
FabMotionDemo
(),
),
new
GalleryItem
(
new
GalleryItem
(
title:
'Grid'
,
title:
'Grid'
,
subtitle:
'Row and column layout'
,
subtitle:
'Row and column layout'
,
...
...
packages/flutter/lib/src/material/floating_action_button_location.dart
View file @
68c77e37
...
@@ -67,7 +67,7 @@ abstract class FloatingActionButtonLocation {
...
@@ -67,7 +67,7 @@ abstract class FloatingActionButtonLocation {
///
///
/// This is unlikely to be a useful location for apps that lack a bottom
/// This is unlikely to be a useful location for apps that lack a bottom
/// navigation bar.
/// navigation bar.
static
FloatingActionButtonLocation
endDocked
=
const
_EndDockedFloatingActionButtonLocation
();
static
const
FloatingActionButtonLocation
endDocked
=
const
_EndDockedFloatingActionButtonLocation
();
/// Center-aligned [FloatingActionButton], floating over the
/// Center-aligned [FloatingActionButton], floating over the
/// [Scaffold.bottomNavigationBar] so that the center of the floating
/// [Scaffold.bottomNavigationBar] so that the center of the floating
...
@@ -79,7 +79,7 @@ abstract class FloatingActionButtonLocation {
...
@@ -79,7 +79,7 @@ abstract class FloatingActionButtonLocation {
///
///
/// This is unlikely to be a useful location for apps that lack a bottom
/// This is unlikely to be a useful location for apps that lack a bottom
/// navigation bar.
/// navigation bar.
static
FloatingActionButtonLocation
centerDocked
=
const
_CenterDockedFloatingActionButtonLocation
();
static
const
FloatingActionButtonLocation
centerDocked
=
const
_CenterDockedFloatingActionButtonLocation
();
/// Places the [FloatingActionButton] based on the [Scaffold]'s layout.
/// Places the [FloatingActionButton] based on the [Scaffold]'s layout.
///
///
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment