Compare commits

..

1 commit

Author SHA1 Message Date
Mehul Ahal
86dbf7e640 added image cache managing 2022-12-22 11:04:51 +01:00
7 changed files with 39 additions and 109 deletions

View file

@ -25,7 +25,7 @@ class UnsplashImagesApi with LoggingService implements ImagesApi {
return ImageModel( return ImageModel(
imageIndex: imageIndex, imageIndex: imageIndex,
uri: imageUri, uri: imageUri,
imageName: '${Strings.current.image} ${imageIndex + 1}: size=$imageSide', imageName: '${Strings.current.image} $imageIndex: size=$imageSide',
); );
}); });
} on Exception catch (ex, stackTrace) { } on Exception catch (ex, stackTrace) {

View file

@ -34,11 +34,5 @@ class ImagesService {
Locator.instance().signalReady(this); Locator.instance().signalReady(this);
} }
int get firstAvailableImageIndex => 0;
int get lastAvailableImageIndex => _imageModels.length - 1;
int get numberOfImages => _imageModels.length;
ImageModel imageModelAt({required int index}) => _imageModels.elementAt(index);
static ImagesService get locate => Locator.locate(); static ImagesService get locate => Locator.locate();
} }

View file

@ -46,6 +46,8 @@ class GalleryView extends StatelessWidget {
context, context,
imageModel: imageModel, imageModel: imageModel,
), ),
child: Hero(
tag: imageModel.imageIndex.toString(),
child: CachedNetworkImage( child: CachedNetworkImage(
imageUrl: imageModel.uri.toString(), imageUrl: imageModel.uri.toString(),
cacheKey: imageModel.imageIndex.toString(), cacheKey: imageModel.imageIndex.toString(),
@ -55,6 +57,7 @@ class GalleryView extends StatelessWidget {
), ),
), ),
), ),
),
], ],
), ),
), ),

View file

@ -1,12 +1,8 @@
import 'package:auto_size_text/auto_size_text.dart';
import 'package:cached_network_image/cached_network_image.dart'; import 'package:cached_network_image/cached_network_image.dart';
import 'package:carousel_slider/carousel_slider.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_markdown/flutter_markdown.dart'; import 'package:flutter_markdown/flutter_markdown.dart';
import 'package:mc_gallery/features/home/data/models/image_model.dart'; import 'package:mc_gallery/features/core/data/constants/const_text.dart';
import '/features/core/data/constants/const_colors.dart';
import '/features/core/data/constants/const_text.dart';
import '/features/core/widgets/gap.dart'; import '/features/core/widgets/gap.dart';
import '/features/core/widgets/mcg_scaffold.dart'; import '/features/core/widgets/mcg_scaffold.dart';
import '/features/core/widgets/view_model_builder.dart'; import '/features/core/widgets/view_model_builder.dart';
@ -31,7 +27,6 @@ class ImageCarouselView extends StatelessWidget {
viewModelBuilder: () => ImageCarouselViewModel.locate, viewModelBuilder: () => ImageCarouselViewModel.locate,
argumentBuilder: () => imageCarouselViewArguments, argumentBuilder: () => imageCarouselViewArguments,
builder: (context, final model) => McgScaffold( builder: (context, final model) => McgScaffold(
bodyBuilderWaiter: model.isInitialised,
appBar: AppBar( appBar: AppBar(
title: Text(model.strings.imageCarousel), title: Text(model.strings.imageCarousel),
), ),
@ -40,24 +35,12 @@ class ImageCarouselView extends StatelessWidget {
Expanded( Expanded(
child: Card( child: Card(
elevation: 8, elevation: 8,
child: CarouselSlider.builder( child: Stack(
itemCount: model.numberOfImages,
options: CarouselOptions(
enlargeFactor: 1,
enlargeCenterPage: true,
enlargeStrategy: CenterPageEnlargeStrategy.scale,
disableCenter: true,
aspectRatio: 1,
initialPage: model.currentImageIndex,
enableInfiniteScroll: false,
onPageChanged: (final index, _) => model.swipedTo(newIndex: index),
),
itemBuilder: (context, _, __) => Stack(
fit: StackFit.expand, fit: StackFit.expand,
children: [ children: [
ValueListenableBuilder<ImageModel>( Hero(
valueListenable: model.currentImageModelListenable, tag: model.currentImageKey,
builder: (context, _, __) => CachedNetworkImage( child: CachedNetworkImage(
imageUrl: model.currentImageUrl, imageUrl: model.currentImageUrl,
cacheKey: model.currentImageKey, cacheKey: model.currentImageKey,
fit: BoxFit.fill, fit: BoxFit.fill,
@ -68,34 +51,15 @@ class ImageCarouselView extends StatelessWidget {
), ),
), ),
Center( Center(
child: ValueListenableBuilder<ImageModel>( child: Text(
valueListenable: model.currentImageModelListenable,
builder: (context, _, __) => Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Icon(
Icons.chevron_left,
color: model.hasPreviousImage
? ConstColours.white
: ConstColours.black,
),
AutoSizeText(
model.currentImageName, model.currentImageName,
style: ConstText.imageOverlayTextStyle(context), style: ConstText.imageOverlayTextStyle(context),
), ),
Icon(
Icons.chevron_right,
color: model.hasNextImage ? ConstColours.white : ConstColours.black,
), ),
], ],
), ),
), ),
), ),
],
),
),
),
),
const Gap(24), const Gap(24),
Padding( Padding(
padding: const EdgeInsets.symmetric(horizontal: 24), padding: const EdgeInsets.symmetric(horizontal: 24),

View file

@ -22,14 +22,13 @@ class ImageCarouselViewModel extends BaseViewModel {
final NavigationService _navigationService; final NavigationService _navigationService;
final LoggingService _loggingService; final LoggingService _loggingService;
late final ValueNotifier<ImageModel> _currentImageModelNotifier; late final ValueNotifier<ImageModel> _currentImageModel;
ValueListenable<ImageModel> get currentImageModelListenable => _currentImageModelNotifier; ValueListenable<ImageModel> get currentImageModel => _currentImageModel;
@override @override
Future<void> initialise(bool Function() mounted, [arguments]) async { Future<void> initialise(bool Function() mounted, [arguments]) async {
_currentImageModelNotifier = ValueNotifier(_imagesService.imageModels _currentImageModel = ValueNotifier(_imagesService.imageModels
.elementAt((arguments! as ImageCarouselViewArguments).imageIndexKey)); .elementAt((arguments! as ImageCarouselViewArguments).imageIndexKey));
_loggingService.info('Initialized with image: ${_currentImageModelNotifier.value.imageIndex}');
super.initialise(mounted, arguments); super.initialise(mounted, arguments);
} }
@ -39,25 +38,11 @@ class ImageCarouselViewModel extends BaseViewModel {
super.dispose(); super.dispose();
} }
void swipedTo({required int newIndex}) { String get currentImageUrl => currentImageModel.value.uri.toString();
_currentImageModelNotifier.value = _imagesService.imageModelAt(index: newIndex); String get currentImageKey => currentImageModel.value.imageIndex.toString();
_loggingService.info('Swiped to image: ${_currentImageModelNotifier.value.imageIndex}'); String get currentImageName => currentImageModel.value.imageName;
}
String get currentImageUrl => currentImageModelListenable.value.uri.toString();
String get currentImageKey => currentImageModelListenable.value.imageIndex.toString();
String get currentImageName => currentImageModelListenable.value.imageName;
int get currentImageIndex => currentImageModelListenable.value.imageIndex;
int get numberOfImages => _imagesService.numberOfImages;
double? downloadProgressValue({required DownloadProgress progress}) => double? downloadProgressValue({required DownloadProgress progress}) =>
progress.totalSize != null ? progress.downloaded / progress.totalSize! : null; progress.totalSize != null ? progress.downloaded / progress.totalSize! : null;
bool get hasPreviousImage =>
currentImageModelListenable.value.imageIndex > _imagesService.firstAvailableImageIndex;
bool get hasNextImage =>
currentImageModelListenable.value.imageIndex < _imagesService.lastAvailableImageIndex;
static ImageCarouselViewModel get locate => Locator.locate(); static ImageCarouselViewModel get locate => Locator.locate();
} }

View file

@ -43,13 +43,6 @@ packages:
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.9.0" version: "2.9.0"
auto_size_text:
dependency: "direct main"
description:
name: auto_size_text
url: "https://pub.dartlang.org"
source: hosted
version: "3.0.0"
boolean_selector: boolean_selector:
dependency: transitive dependency: transitive
description: description:
@ -78,13 +71,6 @@ packages:
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "1.0.2" version: "1.0.2"
carousel_slider:
dependency: "direct main"
description:
name: carousel_slider
url: "https://pub.dartlang.org"
source: hosted
version: "4.2.1"
characters: characters:
dependency: transitive dependency: transitive
description: description:
@ -559,7 +545,7 @@ packages:
name: talker name: talker
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.2.0" version: "2.1.0+1"
talker_dio_logger: talker_dio_logger:
dependency: "direct main" dependency: "direct main"
description: description:
@ -573,7 +559,7 @@ packages:
name: talker_logger name: talker_logger
url: "https://pub.dartlang.org" url: "https://pub.dartlang.org"
source: hosted source: hosted
version: "2.2.0" version: "2.1.0"
term_glyph: term_glyph:
dependency: transitive dependency: transitive
description: description:

View file

@ -32,11 +32,9 @@ dependencies:
# Util frontend # Util frontend
flutter_markdown: ^0.6.13 flutter_markdown: ^0.6.13
auto_size_text: ^3.0.0
carousel_slider: ^4.2.1
# Logging # Logging
talker: ^2.2.0 talker: ^2.1.0+1
talker_dio_logger: ^1.0.0 talker_dio_logger: ^1.0.0
# Assets # Assets