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
6bd578ff
Commit
6bd578ff
authored
Jan 25, 2017
by
Ian Hickson
Committed by
GitHub
Jan 25, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Reword the SystemChrome docs to be in the Flutter voice and style. (#7599)
parent
c47069a6
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
49 additions
and
45 deletions
+49
-45
system_chrome.dart
packages/flutter/lib/src/services/system_chrome.dart
+49
-45
No files found.
packages/flutter/lib/src/services/system_chrome.dart
View file @
6bd578ff
...
@@ -8,19 +8,20 @@ import 'platform_messages.dart';
...
@@ -8,19 +8,20 @@ import 'platform_messages.dart';
/// Specifies a particular device orientation.
/// Specifies a particular device orientation.
///
///
/// Discussion:
///
/// To determine which values correspond to which orientations, first position
/// To determine which values correspond to which orientations, first position
/// the device in its default orientation (this is the orientation that the
/// the device in its default orientation (this is the orientation that the
/// system first uses for its boot logo, or the orientation in which the
/// system first uses for its boot logo, or the orientation in which the
/// hardware logos or markings are upright, or the orientation in which the
/// hardware logos or markings are upright, or the orientation in which the
/// cameras are at the top). If this is a portrait orientation, then this is
/// cameras are at the top). If this is a portrait orientation, then this is
/// [portraitUp]. Otherwise, it's [landscapeLeft]. As you rotate the device by 90
/// [portraitUp]. Otherwise, it's [landscapeLeft]. As you rotate the device by
/// degrees in a counter-clockwise direction around the axis that traverses the
/// 90 degrees in a counter-clockwise direction around the axis that pierces the
/// screen, you step through each value in this enum in the order given. (For a
/// screen, you step through each value in this enum in the order given.
/// device with a landscape default orientation, the orientation obtained by
///
/// rotating the device 90 degrees clockwise from its default orientation is
/// For a device with a landscape default orientation, the orientation obtained
/// [portraitUp].)
/// by rotating the device 90 degrees clockwise from its default orientation is
/// [portraitUp].
///
/// Used by [SystemChrome.setPreferredOrientations].
enum
DeviceOrientation
{
enum
DeviceOrientation
{
/// If the device shows its boot logo in portrait, then the boot logo is shown
/// If the device shows its boot logo in portrait, then the boot logo is shown
/// in [portraitUp]. Otherwise, the device shows its boot logo in landscape
/// in [portraitUp]. Otherwise, the device shows its boot logo in landscape
...
@@ -29,6 +30,9 @@ enum DeviceOrientation {
...
@@ -29,6 +30,9 @@ enum DeviceOrientation {
portraitUp
,
portraitUp
,
/// The orientation that is 90 degrees clockwise from [portraitUp].
/// The orientation that is 90 degrees clockwise from [portraitUp].
///
/// If the device shows its boot logo in landscape, then the boot logo is
/// shown in [landscapeLeft].
landscapeLeft
,
landscapeLeft
,
/// The orientation that is 180 degrees from [portraitUp].
/// The orientation that is 180 degrees from [portraitUp].
...
@@ -39,7 +43,10 @@ enum DeviceOrientation {
...
@@ -39,7 +43,10 @@ enum DeviceOrientation {
}
}
/// Specifies a description of the application that is pertinent to the
/// Specifies a description of the application that is pertinent to the
/// embedder's application switcher (a.k.a. "recent tasks") user interface.
/// embedder's application switcher (also known as "recent tasks") user
/// interface.
///
/// Used by [SystemChrome.setApplicationSwitcherDescription].
class
ApplicationSwitcherDescription
{
class
ApplicationSwitcherDescription
{
/// Creates an ApplicationSwitcherDescription.
/// Creates an ApplicationSwitcherDescription.
const
ApplicationSwitcherDescription
({
this
.
label
,
this
.
primaryColor
});
const
ApplicationSwitcherDescription
({
this
.
label
,
this
.
primaryColor
});
...
@@ -48,23 +55,28 @@ class ApplicationSwitcherDescription {
...
@@ -48,23 +55,28 @@ class ApplicationSwitcherDescription {
final
String
label
;
final
String
label
;
/// The application's primary color.
/// The application's primary color.
///
/// This may influence the color that the operating system uses to represent
/// the application.
final
int
primaryColor
;
final
int
primaryColor
;
}
}
/// Specifies a system overlay at a particular location. Certain platforms
/// Specifies a system overlay at a particular location.
/// may not use all overlays specified here.
///
/// Used by [SystemChrome.setEnabledSystemUIOverlays].
enum
SystemUiOverlay
{
enum
SystemUiOverlay
{
/// The status bar provided by the embedder on the top of the application
/// The status bar provided by the embedder on the top of the application
/// surface
(optional)
/// surface
, if any.
top
,
top
,
/// The status bar provided by the embedder on the bottom of the application
/// The status bar provided by the embedder on the bottom of the application
/// surface
(optional)
/// surface
, if any.
bottom
,
bottom
,
}
}
/// Specifies a preference for the style of the system overlays. Certain
/// Specifies a preference for the style of the system overlays.
/// platforms may not respect this preference.
///
/// Used by [SystemChrome.setSystemUIOverlayStyle].
enum
SystemUiOverlayStyle
{
enum
SystemUiOverlayStyle
{
/// System overlays should be drawn with a light color. Intended for
/// System overlays should be drawn with a light color. Intended for
/// applications with a dark background.
/// applications with a dark background.
...
@@ -84,17 +96,16 @@ List<String> _stringify(List<dynamic> list) {
...
@@ -84,17 +96,16 @@ List<String> _stringify(List<dynamic> list) {
return
result
;
return
result
;
}
}
/// Controls specific aspects of the embedder interface.
/// Controls specific aspects of the operating system's graphical interface and
/// how it interacts with the application.
class
SystemChrome
{
class
SystemChrome
{
SystemChrome
.
_
();
SystemChrome
.
_
();
/// Specifies the set of orientations the application interface can
/// Specifies the set of orientations the application interface can
/// be displayed in.
/// be displayed in.
///
///
/// Arguments:
/// The `orientation` argument is a list of [DeviceOrientation] enum values.
///
/// The empty list is synonymous with having all options enabled.
/// * [orientation]: A list of [DeviceOrientation] enum values. The empty
/// list is synonymous with having all options enabled.
static
Future
<
Null
>
setPreferredOrientations
(
List
<
DeviceOrientation
>
orientations
)
async
{
static
Future
<
Null
>
setPreferredOrientations
(
List
<
DeviceOrientation
>
orientations
)
async
{
await
PlatformMessages
.
invokeMethod
(
await
PlatformMessages
.
invokeMethod
(
_kChannelName
,
_kChannelName
,
...
@@ -104,16 +115,10 @@ class SystemChrome {
...
@@ -104,16 +115,10 @@ class SystemChrome {
}
}
/// Specifies the description of the current state of the application as it
/// Specifies the description of the current state of the application as it
/// pertains to the application switcher (a.k.a "recent tasks").
/// pertains to the application switcher (also known as "recent tasks").
///
/// Arguments:
///
/// * [description]: The application description.
///
/// Platform Specific Notes:
///
///
///
If application-specified metadata is unsupported on the platform,
///
Any part of the description that is unsupported on the current platform
///
specifying it is a no-op and always return true
.
///
will be ignored
.
static
Future
<
Null
>
setApplicationSwitcherDescription
(
ApplicationSwitcherDescription
description
)
async
{
static
Future
<
Null
>
setApplicationSwitcherDescription
(
ApplicationSwitcherDescription
description
)
async
{
await
PlatformMessages
.
invokeMethod
(
await
PlatformMessages
.
invokeMethod
(
_kChannelName
,
_kChannelName
,
...
@@ -125,19 +130,14 @@ class SystemChrome {
...
@@ -125,19 +130,14 @@ class SystemChrome {
);
);
}
}
/// Specifies the set of overlays visible on the embedder when the
/// Specifies the set of system overlays to have visible when the application
/// application is running. The embedder may choose to ignore unsupported
/// is running.
/// overlays
///
///
/// Arguments:
/// The `overlays` argument is a list of [SystemUiOverlay] enum values
/// denoting the overlays to show.
///
///
/// * [overlaysMask]: A mask of [SystemUiOverlay] enum values that denotes
/// If a particular overlay is unsupported on the platform, enabling or
/// the overlays to show.
/// disabling that overlay will be ignored.
///
/// Platform Specific Notes:
///
/// If the overlay is unsupported on the platform, enabling or disabling
/// that overlay is a no-op and always return true.
static
Future
<
Null
>
setEnabledSystemUIOverlays
(
List
<
SystemUiOverlay
>
overlays
)
async
{
static
Future
<
Null
>
setEnabledSystemUIOverlays
(
List
<
SystemUiOverlay
>
overlays
)
async
{
await
PlatformMessages
.
invokeMethod
(
await
PlatformMessages
.
invokeMethod
(
_kChannelName
,
_kChannelName
,
...
@@ -146,13 +146,16 @@ class SystemChrome {
...
@@ -146,13 +146,16 @@ class SystemChrome {
);
);
}
}
/// Specifies the style of the system overlays that are visible on the
/// Specifies the style to use for the system overlays that are visible (if
/// embedder (if any). The embedder may choose to ignore unsupported
/// any).
/// overlays.
///
///
/// This method will schedule the embedder update to be run in a microtask.
/// This method will schedule the embedder update to be run in a microtask.
/// Any subsequent calls to this method during the current event loop will
/// Any subsequent calls to this method during the current event loop will
/// overwrite the pending value to be set on the embedder.
/// overwrite the pending value, such that only the last specified value takes
/// effect.
///
/// If a particular style is not supported on the platform, selecting it will
/// have no effect.
static
void
setSystemUIOverlayStyle
(
SystemUiOverlayStyle
style
)
{
static
void
setSystemUIOverlayStyle
(
SystemUiOverlayStyle
style
)
{
assert
(
style
!=
null
);
assert
(
style
!=
null
);
...
@@ -163,7 +166,8 @@ class SystemChrome {
...
@@ -163,7 +166,8 @@ class SystemChrome {
}
}
if
(
style
==
_latestStyle
)
{
if
(
style
==
_latestStyle
)
{
// Trivial success; no need to queue a microtask.
// Trivial success: no microtask has been queued and the given style is
// already in effect, so no need to queue a microtask.
return
;
return
;
}
}
...
...
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