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
f6353b68
Commit
f6353b68
authored
Aug 30, 2016
by
Hans Muller
Committed by
GitHub
Aug 30, 2016
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Image should handle InheritedWidget ancestor changes (#5656)
parent
22fe5db9
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
139 additions
and
6 deletions
+139
-6
image.dart
packages/flutter/lib/src/widgets/image.dart
+9
-6
image_test.dart
packages/flutter/test/widget/image_test.dart
+130
-0
No files found.
packages/flutter/lib/src/widgets/image.dart
View file @
f6353b68
...
@@ -193,6 +193,15 @@ class _ImageState extends State<Image> {
...
@@ -193,6 +193,15 @@ class _ImageState extends State<Image> {
_resolveImage
();
_resolveImage
();
}
}
@override
void
deactivate
()
{
// If this image is activated again then force _imageStream to be recreated,
// in case the InheritedWidget ancestors it depends on have changed.
_imageStream
?.
removeListener
(
_handleImageChanged
);
_imageStream
=
null
;
super
.
deactivate
();
}
@override
@override
void
dependenciesChanged
()
{
void
dependenciesChanged
()
{
_resolveImage
();
_resolveImage
();
...
@@ -205,12 +214,6 @@ class _ImageState extends State<Image> {
...
@@ -205,12 +214,6 @@ class _ImageState extends State<Image> {
super
.
reassemble
();
super
.
reassemble
();
}
}
@override
void
dispose
()
{
_imageStream
.
removeListener
(
_handleImageChanged
);
super
.
dispose
();
}
void
_resolveImage
()
{
void
_resolveImage
()
{
final
ImageStream
oldImageStream
=
_imageStream
;
final
ImageStream
oldImageStream
=
_imageStream
;
_imageStream
=
config
.
image
.
resolve
(
createLocalImageConfiguration
(
_imageStream
=
config
.
image
.
resolve
(
createLocalImageConfiguration
(
...
...
packages/flutter/test/widget/image_test.dart
View file @
f6353b68
...
@@ -163,16 +163,146 @@ void main() {
...
@@ -163,16 +163,146 @@ void main() {
expect
(
renderImage
.
image
,
isNotNull
);
expect
(
renderImage
.
image
,
isNotNull
);
});
});
testWidgets
(
'Verify ImageProvider configuration inheritance'
,
(
WidgetTester
tester
)
async
{
final
GlobalKey
mediaQueryKey1
=
new
GlobalKey
(
debugLabel:
'mediaQueryKey1'
);
final
GlobalKey
mediaQueryKey2
=
new
GlobalKey
(
debugLabel:
'mediaQueryKey2'
);
final
GlobalKey
imageKey
=
new
GlobalKey
(
debugLabel:
'image'
);
final
TestImageProvider
imageProvider
=
new
TestImageProvider
();
// Of the two nested MediaQuery objects, the innermost one,
// mediaQuery2, should define the configuration of the imageProvider.
await
tester
.
pumpWidget
(
new
MediaQuery
(
key:
mediaQueryKey1
,
data:
new
MediaQueryData
(
devicePixelRatio:
10.0
,
padding:
EdgeInsets
.
zero
,
),
child:
new
MediaQuery
(
key:
mediaQueryKey2
,
data:
new
MediaQueryData
(
devicePixelRatio:
5.0
,
padding:
EdgeInsets
.
zero
,
),
child:
new
Image
(
key:
imageKey
,
image:
imageProvider
),
)
)
);
expect
(
imageProvider
.
_configuration
.
devicePixelRatio
,
5.0
);
// This is the same widget hierarchy as before except that the
// two MediaQuery objects have exchanged places. The imageProvider
// should be resolved again, with the new innermost MediaQuery.
await
tester
.
pumpWidget
(
new
MediaQuery
(
key:
mediaQueryKey2
,
data:
new
MediaQueryData
(
devicePixelRatio:
5.0
,
padding:
EdgeInsets
.
zero
,
),
child:
new
MediaQuery
(
key:
mediaQueryKey1
,
data:
new
MediaQueryData
(
devicePixelRatio:
10.0
,
padding:
EdgeInsets
.
zero
,
),
child:
new
Image
(
key:
imageKey
,
image:
imageProvider
),
)
)
);
expect
(
imageProvider
.
_configuration
.
devicePixelRatio
,
10.0
);
});
testWidgets
(
'Verify ImageProvider configuration inheritance again'
,
(
WidgetTester
tester
)
async
{
final
GlobalKey
mediaQueryKey1
=
new
GlobalKey
(
debugLabel:
'mediaQueryKey1'
);
final
GlobalKey
mediaQueryKey2
=
new
GlobalKey
(
debugLabel:
'mediaQueryKey2'
);
final
GlobalKey
imageKey
=
new
GlobalKey
(
debugLabel:
'image'
);
final
TestImageProvider
imageProvider
=
new
TestImageProvider
();
// This is just a variation on the previous test. In this version the location
// of the Image changes and the MediaQuery widgets do not.
await
tester
.
pumpWidget
(
new
Row
(
children:
<
Widget
>
[
new
MediaQuery
(
key:
mediaQueryKey2
,
data:
new
MediaQueryData
(
devicePixelRatio:
5.0
,
padding:
EdgeInsets
.
zero
,
),
child:
new
Image
(
key:
imageKey
,
image:
imageProvider
)
),
new
MediaQuery
(
key:
mediaQueryKey1
,
data:
new
MediaQueryData
(
devicePixelRatio:
10.0
,
padding:
EdgeInsets
.
zero
,
),
child:
new
Container
(
width:
100.0
)
)
]
)
);
expect
(
imageProvider
.
_configuration
.
devicePixelRatio
,
5.0
);
await
tester
.
pumpWidget
(
new
Row
(
children:
<
Widget
>
[
new
MediaQuery
(
key:
mediaQueryKey2
,
data:
new
MediaQueryData
(
devicePixelRatio:
5.0
,
padding:
EdgeInsets
.
zero
,
),
child:
new
Container
(
width:
100.0
)
),
new
MediaQuery
(
key:
mediaQueryKey1
,
data:
new
MediaQueryData
(
devicePixelRatio:
10.0
,
padding:
EdgeInsets
.
zero
,
),
child:
new
Image
(
key:
imageKey
,
image:
imageProvider
)
)
]
)
);
expect
(
imageProvider
.
_configuration
.
devicePixelRatio
,
10.0
);
});
}
}
class
TestImageProvider
extends
ImageProvider
<
TestImageProvider
>
{
class
TestImageProvider
extends
ImageProvider
<
TestImageProvider
>
{
final
Completer
<
ImageInfo
>
_completer
=
new
Completer
<
ImageInfo
>();
final
Completer
<
ImageInfo
>
_completer
=
new
Completer
<
ImageInfo
>();
ImageConfiguration
_configuration
;
@override
@override
Future
<
TestImageProvider
>
obtainKey
(
ImageConfiguration
configuration
)
{
Future
<
TestImageProvider
>
obtainKey
(
ImageConfiguration
configuration
)
{
return
new
SynchronousFuture
<
TestImageProvider
>(
this
);
return
new
SynchronousFuture
<
TestImageProvider
>(
this
);
}
}
@override
ImageStream
resolve
(
ImageConfiguration
configuration
)
{
_configuration
=
configuration
;
return
super
.
resolve
(
configuration
);
}
@override
@override
ImageStreamCompleter
load
(
TestImageProvider
key
)
=>
new
OneFrameImageStreamCompleter
(
_completer
.
future
);
ImageStreamCompleter
load
(
TestImageProvider
key
)
=>
new
OneFrameImageStreamCompleter
(
_completer
.
future
);
...
...
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