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
82e30c86
Commit
82e30c86
authored
Jan 22, 2016
by
Adam Barth
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Simplify colorizing icons
Now you can colorize an Icon simply by proving a Color for the Icon.
parent
f88c945e
Changes
9
Show whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
64 additions
and
55 deletions
+64
-55
stock_home.dart
examples/stocks/lib/stock_home.dart
+1
-1
chip.dart
packages/flutter/lib/src/material/chip.dart
+1
-4
drawer_item.dart
packages/flutter/lib/src/material/drawer_item.dart
+5
-5
icon.dart
packages/flutter/lib/src/material/icon.dart
+6
-6
icon_button.dart
packages/flutter/lib/src/material/icon_button.dart
+7
-7
tabs.dart
packages/flutter/lib/src/material/tabs.dart
+1
-2
two_level_list.dart
packages/flutter/lib/src/material/two_level_list.dart
+1
-1
image.dart
packages/flutter/lib/src/rendering/image.dart
+21
-8
basic.dart
packages/flutter/lib/src/widgets/basic.dart
+21
-21
No files found.
examples/stocks/lib/stock_home.dart
View file @
82e30c86
...
...
@@ -230,7 +230,7 @@ class StockHomeState extends State<StockHome> {
return
new
ToolBar
(
left:
new
IconButton
(
icon:
'navigation/arrow_back'
,
color
Filter:
new
ColorFilter
.
mode
(
Theme
.
of
(
context
).
accentColor
,
ui
.
TransferMode
.
srcATop
)
,
color
:
Theme
.
of
(
context
).
accentColor
,
onPressed:
_handleSearchEnd
,
tooltip:
'Back'
),
...
...
packages/flutter/lib/src/material/chip.dart
View file @
82e30c86
...
...
@@ -19,9 +19,6 @@ const TextStyle _kLabelStyle = const TextStyle(
textBaseline:
TextBaseline
.
alphabetic
);
final
ColorFilter
_kIconColorFilter
=
new
ColorFilter
.
mode
(
Colors
.
black54
,
TransferMode
.
dstIn
);
class
Chip
extends
StatelessComponent
{
const
Chip
({
Key
key
,
...
...
@@ -66,7 +63,7 @@ class Chip extends StatelessComponent {
child:
new
Icon
(
icon:
'navigation/cancel'
,
size:
IconSize
.
s18
,
color
Filter:
_kIconColorFilter
color
:
Colors
.
black54
)
)
));
...
...
packages/flutter/lib/src/material/drawer_item.dart
View file @
82e30c86
...
...
@@ -23,13 +23,13 @@ class DrawerItem extends StatelessComponent {
final
VoidCallback
onPressed
;
final
bool
selected
;
Color
Filter
_getIconColorFilte
r
(
ThemeData
themeData
)
{
Color
_getIconColo
r
(
ThemeData
themeData
)
{
if
(
selected
)
{
if
(
themeData
.
brightness
==
ThemeBrightness
.
dark
)
return
new
ColorFilter
.
mode
(
themeData
.
accentColor
,
TransferMode
.
srcATop
)
;
return
new
ColorFilter
.
mode
(
themeData
.
primaryColor
,
TransferMode
.
srcATop
)
;
return
themeData
.
accentColor
;
return
themeData
.
primaryColor
;
}
return
new
ColorFilter
.
mode
(
Colors
.
black45
,
TransferMode
.
dstIn
)
;
return
Colors
.
black45
;
}
TextStyle
_getTextStyle
(
ThemeData
themeData
)
{
...
...
@@ -53,7 +53,7 @@ class DrawerItem extends StatelessComponent {
padding:
const
EdgeDims
.
symmetric
(
horizontal:
16.0
),
child:
new
Icon
(
icon:
icon
,
color
Filter:
_getIconColorFilte
r
(
themeData
)
color
:
_getIconColo
r
(
themeData
)
)
)
);
...
...
packages/flutter/lib/src/material/icon.dart
View file @
82e30c86
...
...
@@ -27,8 +27,8 @@ class Icon extends StatelessComponent {
Key
key
,
this
.
size
:
IconSize
.
s24
,
this
.
icon
:
''
,
this
.
color
,
this
.
color
Filter
this
.
color
Theme
,
this
.
color
})
:
super
(
key:
key
)
{
assert
(
size
!=
null
);
assert
(
icon
!=
null
);
...
...
@@ -36,11 +36,11 @@ class Icon extends StatelessComponent {
final
IconSize
size
;
final
String
icon
;
final
IconThemeColor
color
;
final
Color
Filter
colorFilte
r
;
final
IconThemeColor
color
Theme
;
final
Color
colo
r
;
String
_getColorSuffix
(
BuildContext
context
)
{
IconThemeColor
iconThemeColor
=
color
;
IconThemeColor
iconThemeColor
=
color
Theme
;
if
(
iconThemeColor
==
null
)
{
IconThemeData
iconThemeData
=
IconTheme
.
of
(
context
);
iconThemeColor
=
iconThemeData
==
null
?
null
:
iconThemeData
.
color
;
...
...
@@ -74,7 +74,7 @@ class Icon extends StatelessComponent {
name:
'
$category
/
$density
/ic_
${subtype}
_
${colorSuffix}
_
${iconSize}
dp.png'
,
width:
iconSize
.
toDouble
(),
height:
iconSize
.
toDouble
(),
color
Filter:
colorFilte
r
color
:
colo
r
);
}
...
...
packages/flutter/lib/src/material/icon_button.dart
View file @
82e30c86
...
...
@@ -13,15 +13,15 @@ class IconButton extends StatelessComponent {
const
IconButton
({
Key
key
,
this
.
icon
,
this
.
colorTheme
,
this
.
color
,
this
.
colorFilter
,
this
.
onPressed
,
this
.
tooltip
})
:
super
(
key:
key
);
final
String
icon
;
final
IconThemeColor
color
;
final
Color
Filter
colorFilte
r
;
final
IconThemeColor
color
Theme
;
final
Color
colo
r
;
final
VoidCallback
onPressed
;
final
String
tooltip
;
...
...
@@ -32,8 +32,8 @@ class IconButton extends StatelessComponent {
padding:
const
EdgeDims
.
all
(
8.0
),
child:
new
Icon
(
icon:
icon
,
color
:
color
,
color
Filter:
colorFilte
r
color
Theme:
colorTheme
,
color
:
colo
r
)
)
);
...
...
@@ -51,8 +51,8 @@ class IconButton extends StatelessComponent {
description
.
add
(
'
$icon
'
);
if
(
onPressed
==
null
)
description
.
add
(
'disabled'
);
if
(
color
!=
null
)
description
.
add
(
'
$color
'
);
if
(
color
Theme
!=
null
)
description
.
add
(
'
$color
Theme
'
);
if
(
tooltip
!=
null
)
description
.
add
(
'tooltip: "
$tooltip
"'
);
}
...
...
packages/flutter/lib/src/material/tabs.dart
View file @
82e30c86
...
...
@@ -319,8 +319,7 @@ class _Tab extends StatelessComponent {
Widget
_buildLabelIcon
()
{
assert
(
label
.
icon
!=
null
);
ColorFilter
filter
=
new
ColorFilter
.
mode
(
color
,
TransferMode
.
srcATop
);
return
new
Icon
(
icon:
label
.
icon
,
colorFilter:
filter
);
return
new
Icon
(
icon:
label
.
icon
,
color:
color
);
}
Widget
build
(
BuildContext
context
)
{
...
...
packages/flutter/lib/src/material/two_level_list.dart
View file @
82e30c86
...
...
@@ -117,7 +117,7 @@ class _TwoLevelSublistState extends State<TwoLevelSublist> {
turns:
_iconTurns
,
child:
new
Icon
(
icon:
'navigation/expand_more'
,
color
Filter:
new
ColorFilter
.
mode
(
_iconColor
.
evaluate
(
_easeInAnimation
),
TransferMode
.
srcATop
)
color
:
_iconColor
.
evaluate
(
_easeInAnimation
)
)
)
),
...
...
packages/flutter/lib/src/rendering/image.dart
View file @
82e30c86
...
...
@@ -22,7 +22,7 @@ class RenderImage extends RenderBox {
ui
.
Image
image
,
double
width
,
double
height
,
Color
Filter
colorFilte
r
,
Color
colo
r
,
ImageFit
fit
,
FractionalOffset
alignment
,
ImageRepeat
repeat:
ImageRepeat
.
noRepeat
,
...
...
@@ -30,11 +30,13 @@ class RenderImage extends RenderBox {
})
:
_image
=
image
,
_width
=
width
,
_height
=
height
,
_color
Filter
=
colorFilte
r
,
_color
=
colo
r
,
_fit
=
fit
,
_alignment
=
alignment
,
_repeat
=
repeat
,
_centerSlice
=
centerSlice
;
_centerSlice
=
centerSlice
{
_updateColorFilter
();
}
/// The image to display.
ui
.
Image
get
image
=>
_image
;
...
...
@@ -74,13 +76,24 @@ class RenderImage extends RenderBox {
markNeedsLayout
();
}
/// If non-null, apply this color filter to the image before painint.
ColorFilter
get
colorFilter
=>
_colorFilter
;
ColorFilter
_colorFilter
;
void
set
colorFilter
(
ColorFilter
value
)
{
if
(
value
==
_colorFilter
)
// Should we make the transfer mode configurable?
void
_updateColorFilter
()
{
if
(
_color
==
null
)
_colorFilter
=
null
;
else
_colorFilter
=
new
ColorFilter
.
mode
(
_color
,
TransferMode
.
srcIn
);
}
/// If non-null, apply this color filter to the image before painting.
Color
get
color
=>
_color
;
Color
_color
;
void
set
color
(
Color
value
)
{
if
(
value
==
_color
)
return
;
_colorFilter
=
value
;
_color
=
value
;
_updateColorFilter
();
markNeedsPaint
();
}
...
...
packages/flutter/lib/src/widgets/basic.dart
View file @
82e30c86
...
...
@@ -1482,7 +1482,7 @@ class RawImage extends LeafRenderObjectWidget {
this
.
image
,
this
.
width
,
this
.
height
,
this
.
color
Filter
,
this
.
color
,
this
.
fit
,
this
.
alignment
,
this
.
repeat
:
ImageRepeat
.
noRepeat
,
...
...
@@ -1504,8 +1504,8 @@ class RawImage extends LeafRenderObjectWidget {
/// aspect ratio.
final
double
height
;
/// If non-null, apply this color filter to the image before pain
int
.
final
Color
Filter
colorFilte
r
;
/// If non-null, apply this color filter to the image before pain
ting
.
final
Color
colo
r
;
/// How to inscribe the image into the place allocated during layout.
final
ImageFit
fit
;
...
...
@@ -1533,7 +1533,7 @@ class RawImage extends LeafRenderObjectWidget {
image:
image
,
width:
width
,
height:
height
,
color
Filter:
colorFilte
r
,
color
:
colo
r
,
fit:
fit
,
alignment:
alignment
,
repeat:
repeat
,
...
...
@@ -1543,7 +1543,7 @@ class RawImage extends LeafRenderObjectWidget {
renderObject
.
image
=
image
;
renderObject
.
width
=
width
;
renderObject
.
height
=
height
;
renderObject
.
color
Filter
=
colorFilte
r
;
renderObject
.
color
=
colo
r
;
renderObject
.
alignment
=
alignment
;
renderObject
.
fit
=
fit
;
renderObject
.
repeat
=
repeat
;
...
...
@@ -1566,7 +1566,7 @@ class RawImageResource extends StatefulComponent {
this
.
image
,
this
.
width
,
this
.
height
,
this
.
color
Filter
,
this
.
color
,
this
.
fit
,
this
.
alignment
,
this
.
repeat
:
ImageRepeat
.
noRepeat
,
...
...
@@ -1590,8 +1590,8 @@ class RawImageResource extends StatefulComponent {
/// aspect ratio.
final
double
height
;
/// If non-null, apply this color filter to the image before pain
int
.
final
Color
Filter
colorFilte
r
;
/// If non-null, apply this color filter to the image before pain
ting
.
final
Color
colo
r
;
/// How to inscribe the image into the place allocated during layout.
final
ImageFit
fit
;
...
...
@@ -1649,7 +1649,7 @@ class _ImageListenerState extends State<RawImageResource> {
image:
_resolvedImage
,
width:
config
.
width
,
height:
config
.
height
,
color
Filter:
config
.
colorFilte
r
,
color
:
config
.
colo
r
,
fit:
config
.
fit
,
alignment:
config
.
alignment
,
repeat:
config
.
repeat
,
...
...
@@ -1665,7 +1665,7 @@ class NetworkImage extends StatelessComponent {
this
.
src
,
this
.
width
,
this
.
height
,
this
.
color
Filter
,
this
.
color
,
this
.
fit
,
this
.
alignment
,
this
.
repeat
:
ImageRepeat
.
noRepeat
,
...
...
@@ -1687,8 +1687,8 @@ class NetworkImage extends StatelessComponent {
/// aspect ratio.
final
double
height
;
/// If non-null, apply this color filter to the image before pain
int
.
final
Color
Filter
colorFilte
r
;
/// If non-null, apply this color filter to the image before pain
ting
.
final
Color
colo
r
;
/// How to inscribe the image into the place allocated during layout.
final
ImageFit
fit
;
...
...
@@ -1717,7 +1717,7 @@ class NetworkImage extends StatelessComponent {
image:
imageCache
.
load
(
src
),
width:
width
,
height:
height
,
color
Filter:
colorFilte
r
,
color
:
colo
r
,
fit:
fit
,
alignment:
alignment
,
repeat:
repeat
,
...
...
@@ -1763,7 +1763,7 @@ class AsyncImage extends StatelessComponent {
this
.
provider
,
this
.
width
,
this
.
height
,
this
.
color
Filter
,
this
.
color
,
this
.
fit
,
this
.
alignment
,
this
.
repeat
:
ImageRepeat
.
noRepeat
,
...
...
@@ -1785,8 +1785,8 @@ class AsyncImage extends StatelessComponent {
/// aspect ratio.
final
double
height
;
/// If non-null, apply this color filter to the image before pain
int
.
final
Color
Filter
colorFilte
r
;
/// If non-null, apply this color filter to the image before pain
ting
.
final
Color
colo
r
;
/// How to inscribe the image into the place allocated during layout.
final
ImageFit
fit
;
...
...
@@ -1815,7 +1815,7 @@ class AsyncImage extends StatelessComponent {
image:
imageCache
.
loadProvider
(
provider
),
width:
width
,
height:
height
,
color
Filter:
colorFilte
r
,
color
:
colo
r
,
fit:
fit
,
alignment:
alignment
,
repeat:
repeat
,
...
...
@@ -1837,7 +1837,7 @@ class AssetImage extends StatelessComponent {
this
.
bundle
,
this
.
width
,
this
.
height
,
this
.
color
Filter
,
this
.
color
,
this
.
fit
,
this
.
alignment
,
this
.
repeat
:
ImageRepeat
.
noRepeat
,
...
...
@@ -1865,8 +1865,8 @@ class AssetImage extends StatelessComponent {
/// aspect ratio.
final
double
height
;
/// If non-null, apply this color filter to the image before pain
int
.
final
Color
Filter
colorFilte
r
;
/// If non-null, apply this color filter to the image before pain
ting
.
final
Color
colo
r
;
/// How to inscribe the image into the place allocated during layout.
final
ImageFit
fit
;
...
...
@@ -1895,7 +1895,7 @@ class AssetImage extends StatelessComponent {
image:
(
bundle
??
DefaultAssetBundle
.
of
(
context
)).
loadImage
(
name
),
width:
width
,
height:
height
,
color
Filter:
colorFilte
r
,
color
:
colo
r
,
fit:
fit
,
alignment:
alignment
,
repeat:
repeat
,
...
...
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