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
2701b469
Commit
2701b469
authored
Aug 11, 2015
by
Adam Barth
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #545 from abarth/image_resource
Use ImageResource instead of Future<sky.Image>
parents
d2d9ae13
9f228349
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
136 additions
and
53 deletions
+136
-53
image_map.dart
examples/game/lib/image_map.dart
+1
-1
image_resource.dart
packages/flutter/lib/base/image_resource.dart
+42
-0
asset_bundle.dart
packages/flutter/lib/mojo/asset_bundle.dart
+6
-5
image_cache.dart
packages/flutter/lib/mojo/net/image_cache.dart
+4
-4
box_painter.dart
packages/flutter/lib/painting/box_painter.dart
+30
-20
box.dart
packages/flutter/lib/rendering/box.dart
+30
-5
basic.dart
packages/flutter/lib/widgets/basic.dart
+23
-18
No files found.
examples/game/lib/image_map.dart
View file @
2701b469
...
@@ -15,7 +15,7 @@ class ImageMap {
...
@@ -15,7 +15,7 @@ class ImageMap {
}
}
Future
<
Image
>
_loadImage
(
String
url
)
async
{
Future
<
Image
>
_loadImage
(
String
url
)
async
{
Image
image
=
await
_bundle
.
loadImage
(
url
);
Image
image
=
await
_bundle
.
loadImage
(
url
)
.
first
;
_images
[
url
]
=
image
;
_images
[
url
]
=
image
;
return
image
;
return
image
;
}
}
...
...
packages/flutter/lib/base/image_resource.dart
0 → 100644
View file @
2701b469
// Copyright 2015 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
'dart:async'
;
import
'dart:sky'
as
sky
;
typedef
void
ImageListener
(
sky
.
Image
image
);
class
ImageResource
{
ImageResource
(
this
.
_futureImage
)
{
_futureImage
.
then
((
sky
.
Image
image
)
{
_image
=
image
;
_resolved
=
true
;
_notifyListeners
();
});
}
bool
_resolved
=
false
;
Future
<
sky
.
Image
>
_futureImage
;
sky
.
Image
_image
;
final
List
<
ImageListener
>
_listeners
=
new
List
<
ImageListener
>();
Future
<
sky
.
Image
>
get
first
=>
_futureImage
;
void
addListener
(
ImageListener
listener
)
{
_listeners
.
add
(
listener
);
if
(
_resolved
)
listener
(
_image
);
}
void
removeListener
(
ImageListener
listener
)
{
_listeners
.
remove
(
listener
);
}
void
_notifyListeners
()
{
assert
(
_resolved
);
List
<
ImageListener
>
localListeners
=
new
List
<
ImageListener
>.
from
(
_listeners
);
for
(
ImageListener
listener
in
localListeners
)
listener
(
_image
);
}
}
packages/flutter/lib/mojo/asset_bundle.dart
View file @
2701b469
...
@@ -9,13 +9,14 @@ import 'dart:typed_data';
...
@@ -9,13 +9,14 @@ import 'dart:typed_data';
import
'package:mojo/core.dart'
as
core
;
import
'package:mojo/core.dart'
as
core
;
import
'package:mojo_services/mojo/asset_bundle/asset_bundle.mojom.dart'
;
import
'package:mojo_services/mojo/asset_bundle/asset_bundle.mojom.dart'
;
import
'package:sky/base/image_resource.dart'
;
import
'package:sky/mojo/net/fetch.dart'
;
import
'package:sky/mojo/net/fetch.dart'
;
import
'package:sky/mojo/net/image_cache.dart'
as
image_cache
;
import
'package:sky/mojo/net/image_cache.dart'
as
image_cache
;
import
'package:sky/mojo/shell.dart'
as
shell
;
import
'package:sky/mojo/shell.dart'
as
shell
;
abstract
class
AssetBundle
{
abstract
class
AssetBundle
{
void
close
();
void
close
();
Future
<
sky
.
Image
>
loadImage
(
String
key
);
ImageResource
loadImage
(
String
key
);
Future
<
String
>
loadString
(
String
key
);
Future
<
String
>
loadString
(
String
key
);
}
}
...
@@ -26,7 +27,7 @@ class NetworkAssetBundle extends AssetBundle {
...
@@ -26,7 +27,7 @@ class NetworkAssetBundle extends AssetBundle {
void
close
()
{
}
void
close
()
{
}
Future
<
sky
.
Image
>
loadImage
(
String
key
)
{
ImageResource
loadImage
(
String
key
)
{
return
image_cache
.
load
(
_baseUrl
.
resolve
(
key
).
toString
());
return
image_cache
.
load
(
_baseUrl
.
resolve
(
key
).
toString
());
}
}
...
@@ -53,7 +54,7 @@ class MojoAssetBundle extends AssetBundle {
...
@@ -53,7 +54,7 @@ class MojoAssetBundle extends AssetBundle {
}
}
AssetBundleProxy
_bundle
;
AssetBundleProxy
_bundle
;
Map
<
String
,
Future
<
sky
.
Image
>>
_imageCache
=
new
Map
<
String
,
Future
<
sky
.
Image
>
>();
Map
<
String
,
ImageResource
>
_imageCache
=
new
Map
<
String
,
ImageResource
>();
Map
<
String
,
Future
<
String
>>
_stringCache
=
new
Map
<
String
,
Future
<
String
>>();
Map
<
String
,
Future
<
String
>>
_stringCache
=
new
Map
<
String
,
Future
<
String
>>();
void
close
()
{
void
close
()
{
...
@@ -62,13 +63,13 @@ class MojoAssetBundle extends AssetBundle {
...
@@ -62,13 +63,13 @@ class MojoAssetBundle extends AssetBundle {
_imageCache
=
null
;
_imageCache
=
null
;
}
}
Future
<
sky
.
Image
>
loadImage
(
String
key
)
{
ImageResource
loadImage
(
String
key
)
{
return
_imageCache
.
putIfAbsent
(
key
,
()
{
return
_imageCache
.
putIfAbsent
(
key
,
()
{
Completer
<
sky
.
Image
>
completer
=
new
Completer
<
sky
.
Image
>();
Completer
<
sky
.
Image
>
completer
=
new
Completer
<
sky
.
Image
>();
_bundle
.
ptr
.
getAsStream
(
key
).
then
((
response
)
{
_bundle
.
ptr
.
getAsStream
(
key
).
then
((
response
)
{
new
sky
.
ImageDecoder
(
response
.
assetData
.
handle
.
h
,
completer
.
complete
);
new
sky
.
ImageDecoder
(
response
.
assetData
.
handle
.
h
,
completer
.
complete
);
});
});
return
completer
.
future
;
return
new
ImageResource
(
completer
.
future
)
;
});
});
}
}
...
...
packages/flutter/lib/mojo/net/image_cache.dart
View file @
2701b469
...
@@ -7,12 +7,12 @@ import 'dart:collection';
...
@@ -7,12 +7,12 @@ import 'dart:collection';
import
'dart:sky'
as
sky
;
import
'dart:sky'
as
sky
;
import
'package:mojo/mojo/url_response.mojom.dart'
;
import
'package:mojo/mojo/url_response.mojom.dart'
;
import
'package:sky/base/image_resource.dart'
;
import
'package:sky/mojo/net/fetch.dart'
;
import
'package:sky/mojo/net/fetch.dart'
;
final
HashMap
<
String
,
Future
<
sky
.
Image
>>
_cache
=
final
HashMap
<
String
,
ImageResource
>
_cache
=
new
Map
<
String
,
ImageResource
>();
new
HashMap
<
String
,
Future
<
sky
.
Image
>>();
Future
<
sky
.
Image
>
load
(
String
url
)
{
ImageResource
load
(
String
url
)
{
return
_cache
.
putIfAbsent
(
url
,
()
{
return
_cache
.
putIfAbsent
(
url
,
()
{
Completer
<
sky
.
Image
>
completer
=
new
Completer
<
sky
.
Image
>();
Completer
<
sky
.
Image
>
completer
=
new
Completer
<
sky
.
Image
>();
fetchUrl
(
url
).
then
((
UrlResponse
response
)
{
fetchUrl
(
url
).
then
((
UrlResponse
response
)
{
...
@@ -23,6 +23,6 @@ Future<sky.Image> load(String url) {
...
@@ -23,6 +23,6 @@ Future<sky.Image> load(String url) {
new
sky
.
ImageDecoder
(
response
.
body
.
handle
.
h
,
completer
.
complete
);
new
sky
.
ImageDecoder
(
response
.
body
.
handle
.
h
,
completer
.
complete
);
}
}
});
});
return
completer
.
future
;
return
new
ImageResource
(
completer
.
future
)
;
});
});
}
}
packages/flutter/lib/painting/box_painter.dart
View file @
2701b469
...
@@ -2,11 +2,11 @@
...
@@ -2,11 +2,11 @@
// Use of this source code is governed by a BSD-style license that can be
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// found in the LICENSE file.
import
'dart:async'
;
import
'dart:math'
as
math
;
import
'dart:math'
as
math
;
import
'dart:sky'
as
sky
;
import
'dart:sky'
as
sky
;
import
'dart:sky'
show
Point
,
Offset
,
Size
,
Rect
,
Color
,
Paint
,
Path
;
import
'dart:sky'
show
Point
,
Offset
,
Size
,
Rect
,
Color
,
Paint
,
Path
;
import
'package:sky/base/image_resource.dart'
;
import
'package:sky/base/lerp.dart'
;
import
'package:sky/base/lerp.dart'
;
import
'package:sky/painting/shadows.dart'
;
import
'package:sky/painting/shadows.dart'
;
...
@@ -168,10 +168,7 @@ enum BackgroundFit { fill, contain, cover, none, scaleDown }
...
@@ -168,10 +168,7 @@ enum BackgroundFit { fill, contain, cover, none, scaleDown }
enum
BackgroundRepeat
{
repeat
,
repeatX
,
repeatY
,
noRepeat
}
enum
BackgroundRepeat
{
repeat
,
repeatX
,
repeatY
,
noRepeat
}
// TODO(jackson): We should abstract this out into a separate class
typedef
void
BackgroundImageChangeListener
(
);
// that handles the image caching and so forth, which has callbacks
// for "size changed" and "image changed". This would also enable us
// to do animated images.
class
BackgroundImage
{
class
BackgroundImage
{
final
BackgroundFit
fit
;
final
BackgroundFit
fit
;
...
@@ -179,35 +176,48 @@ class BackgroundImage {
...
@@ -179,35 +176,48 @@ class BackgroundImage {
final
sky
.
ColorFilter
colorFilter
;
final
sky
.
ColorFilter
colorFilter
;
BackgroundImage
({
BackgroundImage
({
Future
<
sky
.
Image
>
image
,
ImageResource
image
,
this
.
fit
:
BackgroundFit
.
scaleDown
,
this
.
fit
:
BackgroundFit
.
scaleDown
,
this
.
repeat
:
BackgroundRepeat
.
noRepeat
,
this
.
repeat
:
BackgroundRepeat
.
noRepeat
,
this
.
colorFilter
this
.
colorFilter
})
{
})
:
_imageResource
=
image
;
image
.
then
((
resolvedImage
)
{
if
(
resolvedImage
==
null
)
return
;
_image
=
resolvedImage
;
_size
=
new
Size
(
resolvedImage
.
width
.
toDouble
(),
resolvedImage
.
height
.
toDouble
());
for
(
Function
listener
in
_listeners
)
{
listener
();
}
});
}
sky
.
Image
_image
;
sky
.
Image
_image
;
sky
.
Image
get
image
=>
_image
;
sky
.
Image
get
image
=>
_image
;
ImageResource
_imageResource
;
Size
_size
;
Size
_size
;
final
List
<
Function
>
_listeners
=
new
List
<
Function
>();
final
List
<
BackgroundImageChangeListener
>
_listeners
=
new
List
<
BackgroundImageChangeListener
>();
void
addChangeListener
(
Function
listener
)
{
void
addChangeListener
(
BackgroundImageChangeListener
listener
)
{
// We add the listener to the _imageResource first so that the first change
// listener doesn't get callback synchronously if the image resource is
// already resolved.
if
(
_listeners
.
isEmpty
)
_imageResource
.
addListener
(
_handleImageChanged
);
_listeners
.
add
(
listener
);
_listeners
.
add
(
listener
);
}
}
void
removeChangeListener
(
Function
listener
)
{
void
removeChangeListener
(
BackgroundImageChangeListener
listener
)
{
_listeners
.
remove
(
listener
);
_listeners
.
remove
(
listener
);
// We need to remove ourselves as listeners from the _imageResource so that
// we're not kept alive by the image_cache.
if
(
_listeners
.
isEmpty
)
_imageResource
.
removeListener
(
_handleImageChanged
);
}
void
_handleImageChanged
(
sky
.
Image
resolvedImage
)
{
if
(
resolvedImage
==
null
)
return
;
_image
=
resolvedImage
;
_size
=
new
Size
(
resolvedImage
.
width
.
toDouble
(),
resolvedImage
.
height
.
toDouble
());
final
List
<
BackgroundImageChangeListener
>
localListeners
=
new
List
<
BackgroundImageChangeListener
>.
from
(
_listeners
);
for
(
BackgroundImageChangeListener
listener
in
localListeners
)
{
listener
();
}
}
}
String
toString
()
=>
'BackgroundImage(
$fit
,
$repeat
)'
;
String
toString
()
=>
'BackgroundImage(
$fit
,
$repeat
)'
;
...
...
packages/flutter/lib/rendering/box.dart
View file @
2701b469
...
@@ -1475,20 +1475,45 @@ class RenderDecoratedBox extends RenderProxyBox {
...
@@ -1475,20 +1475,45 @@ class RenderDecoratedBox extends RenderProxyBox {
RenderBox
child
RenderBox
child
})
:
_painter
=
new
BoxPainter
(
decoration
),
super
(
child
);
})
:
_painter
=
new
BoxPainter
(
decoration
),
super
(
child
);
BoxPainter
_painter
;
final
BoxPainter
_painter
;
BoxDecoration
get
decoration
=>
_painter
.
decoration
;
BoxDecoration
get
decoration
=>
_painter
.
decoration
;
void
set
decoration
(
BoxDecoration
value
)
{
void
set
decoration
(
BoxDecoration
value
)
{
assert
(
value
!=
null
);
assert
(
value
!=
null
);
if
(
_painter
.
decoration
.
backgroundImage
!=
null
)
_painter
.
decoration
.
backgroundImage
.
removeChangeListener
(
markNeedsPaint
);
if
(
value
.
backgroundImage
!=
null
)
value
.
backgroundImage
.
addChangeListener
(
markNeedsPaint
);
if
(
value
==
_painter
.
decoration
)
if
(
value
==
_painter
.
decoration
)
return
;
return
;
_removeBackgroundImageListenerIfNeeded
();
_painter
.
decoration
=
value
;
_painter
.
decoration
=
value
;
_addBackgroundImageListenerIfNeeded
();
markNeedsPaint
();
markNeedsPaint
();
}
}
bool
get
_needsBackgroundImageListener
{
return
attached
&&
_painter
.
decoration
!=
null
&&
_painter
.
decoration
.
backgroundImage
!=
null
;
}
void
_addBackgroundImageListenerIfNeeded
()
{
if
(
_needsBackgroundImageListener
)
_painter
.
decoration
.
backgroundImage
.
addChangeListener
(
markNeedsPaint
);
}
void
_removeBackgroundImageListenerIfNeeded
()
{
if
(
_needsBackgroundImageListener
)
_painter
.
decoration
.
backgroundImage
.
removeChangeListener
(
markNeedsPaint
);
}
void
attach
()
{
super
.
attach
();
_addBackgroundImageListenerIfNeeded
();
}
void
detach
()
{
_removeBackgroundImageListenerIfNeeded
();
super
.
detach
();
}
void
paint
(
PaintingCanvas
canvas
,
Offset
offset
)
{
void
paint
(
PaintingCanvas
canvas
,
Offset
offset
)
{
assert
(
size
.
width
!=
null
);
assert
(
size
.
width
!=
null
);
assert
(
size
.
height
!=
null
);
assert
(
size
.
height
!=
null
);
...
...
packages/flutter/lib/widgets/basic.dart
View file @
2701b469
...
@@ -2,11 +2,11 @@
...
@@ -2,11 +2,11 @@
// Use of this source code is governed by a BSD-style license that can be
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// found in the LICENSE file.
import
'dart:async'
;
import
'dart:sky'
as
sky
;
import
'dart:sky'
as
sky
;
import
'package:vector_math/vector_math.dart'
;
import
'package:vector_math/vector_math.dart'
;
import
'package:sky/base/image_resource.dart'
;
import
'package:sky/mojo/asset_bundle.dart'
;
import
'package:sky/mojo/asset_bundle.dart'
;
import
'package:sky/mojo/net/image_cache.dart'
as
image_cache
;
import
'package:sky/mojo/net/image_cache.dart'
as
image_cache
;
import
'package:sky/painting/text_style.dart'
;
import
'package:sky/painting/text_style.dart'
;
...
@@ -530,39 +530,44 @@ class Image extends LeafRenderObjectWrapper {
...
@@ -530,39 +530,44 @@ class Image extends LeafRenderObjectWrapper {
}
}
}
}
class
FutureImage
extends
StatefulComponent
{
class
ImageListener
extends
StatefulComponent
{
FutureImage
({
Key
key
,
this
.
image
,
this
.
width
,
this
.
height
,
this
.
colorFilter
})
:
super
(
key:
key
);
ImageListener
({
Key
key
,
this
.
image
,
this
.
width
,
this
.
height
,
this
.
colorFilter
})
:
super
(
key:
key
);
Future
<
sky
.
Image
>
image
;
ImageResource
image
;
double
width
;
double
width
;
double
height
;
double
height
;
sky
.
ColorFilter
colorFilter
;
sky
.
ColorFilter
colorFilter
;
sky
.
Image
_resolvedImage
;
sky
.
Image
_resolvedImage
;
void
_resolveImage
()
{
void
_handleImageChanged
(
sky
.
Image
resolvedImage
)
{
image
.
then
((
sky
.
Image
resolvedImage
)
{
if
(!
mounted
)
if
(!
mounted
)
return
;
return
;
setState
(()
{
setState
(()
{
_resolvedImage
=
resolvedImage
;
_resolvedImage
=
resolvedImage
;
});
});
});
}
}
void
didMount
()
{
void
didMount
()
{
super
.
didMount
();
super
.
didMount
();
_resolveImage
(
);
image
.
addListener
(
_handleImageChanged
);
}
}
void
syncFields
(
FutureImage
source
)
{
void
didUnmount
()
{
bool
needToResolveImage
=
(
image
!=
source
.
image
);
super
.
didUnmount
();
image
.
removeListener
(
_handleImageChanged
);
}
void
syncFields
(
ImageListener
source
)
{
final
bool
needToUpdateListeners
=
(
image
!=
source
.
image
)
&&
mounted
;
if
(
needToUpdateListeners
)
image
.
removeListener
(
_handleImageChanged
);
image
=
source
.
image
;
image
=
source
.
image
;
width
=
source
.
width
;
width
=
source
.
width
;
height
=
source
.
height
;
height
=
source
.
height
;
colorFilter
=
source
.
colorFilter
;
colorFilter
=
source
.
colorFilter
;
if
(
needTo
ResolveImage
)
if
(
needTo
UpdateListeners
)
_resolveImage
(
);
image
.
addListener
(
_handleImageChanged
);
}
}
Widget
build
()
{
Widget
build
()
{
...
@@ -584,7 +589,7 @@ class NetworkImage extends Component {
...
@@ -584,7 +589,7 @@ class NetworkImage extends Component {
final
sky
.
ColorFilter
colorFilter
;
final
sky
.
ColorFilter
colorFilter
;
Widget
build
()
{
Widget
build
()
{
return
new
FutureImage
(
return
new
ImageListener
(
image:
image_cache
.
load
(
src
),
image:
image_cache
.
load
(
src
),
width:
width
,
width:
width
,
height:
height
,
height:
height
,
...
@@ -603,7 +608,7 @@ class AssetImage extends Component {
...
@@ -603,7 +608,7 @@ class AssetImage extends Component {
final
sky
.
ColorFilter
colorFilter
;
final
sky
.
ColorFilter
colorFilter
;
Widget
build
()
{
Widget
build
()
{
return
new
FutureImage
(
return
new
ImageListener
(
image:
bundle
.
loadImage
(
name
),
image:
bundle
.
loadImage
(
name
),
width:
width
,
width:
width
,
height:
height
,
height:
height
,
...
...
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