mirror of
https://github.com/vodemn/m3_lightmeter.git
synced 2024-11-21 23:10:40 +00:00
display selected exposure pair on timer screen
This commit is contained in:
parent
04bd00b2c0
commit
43ab97f87f
6 changed files with 92 additions and 58 deletions
|
@ -117,5 +117,6 @@
|
||||||
"tooltipResetToZero": "Reset to zero",
|
"tooltipResetToZero": "Reset to zero",
|
||||||
"tooltipUseLightSensor": "Use lightsensor",
|
"tooltipUseLightSensor": "Use lightsensor",
|
||||||
"tooltipUseCamera": "Use camera",
|
"tooltipUseCamera": "Use camera",
|
||||||
"tooltipOpenSettings": "Open settings"
|
"tooltipOpenSettings": "Open settings",
|
||||||
|
"exposurePair": "Exposure pair"
|
||||||
}
|
}
|
|
@ -117,5 +117,6 @@
|
||||||
"tooltipResetToZero": "Remise à zéro",
|
"tooltipResetToZero": "Remise à zéro",
|
||||||
"tooltipUseLightSensor": "Utiliser un capteur de lumière",
|
"tooltipUseLightSensor": "Utiliser un capteur de lumière",
|
||||||
"tooltipUseCamera": "Utiliser la caméra",
|
"tooltipUseCamera": "Utiliser la caméra",
|
||||||
"tooltipOpenSettings": "Ouvrir les paramètres"
|
"tooltipOpenSettings": "Ouvrir les paramètres",
|
||||||
|
"exposurePair": "Paire d'exposition"
|
||||||
}
|
}
|
|
@ -117,5 +117,6 @@
|
||||||
"tooltipResetToZero": "Сбросить до 0",
|
"tooltipResetToZero": "Сбросить до 0",
|
||||||
"tooltipUseLightSensor": "Использовать датчик освещенности",
|
"tooltipUseLightSensor": "Использовать датчик освещенности",
|
||||||
"tooltipUseCamera": "Использовать камеру",
|
"tooltipUseCamera": "Использовать камеру",
|
||||||
"tooltipOpenSettings": "Открыть настройки"
|
"tooltipOpenSettings": "Открыть настройки",
|
||||||
|
"exposurePair": "Пара экспозиции"
|
||||||
}
|
}
|
|
@ -117,5 +117,6 @@
|
||||||
"resetToZero": "重置为零",
|
"resetToZero": "重置为零",
|
||||||
"tooltipUseLightSensor": "使用光线传感器",
|
"tooltipUseLightSensor": "使用光线传感器",
|
||||||
"tooltipUseCamera": "使用摄像头",
|
"tooltipUseCamera": "使用摄像头",
|
||||||
"tooltipOpenSettings": "打开设置"
|
"tooltipOpenSettings": "打开设置",
|
||||||
|
"exposurePair": "曝光对"
|
||||||
}
|
}
|
|
@ -0,0 +1,43 @@
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:lightmeter/data/models/exposure_pair.dart';
|
||||||
|
import 'package:lightmeter/generated/l10n.dart';
|
||||||
|
import 'package:lightmeter/res/dimens.dart';
|
||||||
|
import 'package:lightmeter/screens/metering/components/shared/readings_container/components/shared/reading_value_container/widget_container_reading_value.dart';
|
||||||
|
|
||||||
|
class TimerMeteringConfig extends StatelessWidget {
|
||||||
|
final ExposurePair exposurePair;
|
||||||
|
|
||||||
|
const TimerMeteringConfig({
|
||||||
|
required this.exposurePair,
|
||||||
|
super.key,
|
||||||
|
});
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Container(
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
color: Theme.of(context).colorScheme.surface,
|
||||||
|
borderRadius: const BorderRadius.only(
|
||||||
|
bottomLeft: Radius.circular(Dimens.borderRadiusL),
|
||||||
|
bottomRight: Radius.circular(Dimens.borderRadiusL),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
padding: const EdgeInsets.all(Dimens.paddingM),
|
||||||
|
child: SafeArea(
|
||||||
|
bottom: false,
|
||||||
|
child: Row(
|
||||||
|
children: [
|
||||||
|
Expanded(
|
||||||
|
child: ReadingValueContainer.singleValue(
|
||||||
|
value: ReadingValue(
|
||||||
|
label: S.of(context).exposurePair,
|
||||||
|
value: exposurePair.toString(),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
|
@ -4,6 +4,7 @@ import 'package:lightmeter/data/models/exposure_pair.dart';
|
||||||
import 'package:lightmeter/res/dimens.dart';
|
import 'package:lightmeter/res/dimens.dart';
|
||||||
import 'package:lightmeter/screens/shared/bottom_controls_bar/widget_bottom_controls_bar.dart';
|
import 'package:lightmeter/screens/shared/bottom_controls_bar/widget_bottom_controls_bar.dart';
|
||||||
import 'package:lightmeter/screens/timer/bloc_timer.dart';
|
import 'package:lightmeter/screens/timer/bloc_timer.dart';
|
||||||
|
import 'package:lightmeter/screens/timer/components/metering_config/widget_metering_config_timer.dart';
|
||||||
import 'package:lightmeter/screens/timer/components/text/widget_text_timer.dart';
|
import 'package:lightmeter/screens/timer/components/text/widget_text_timer.dart';
|
||||||
import 'package:lightmeter/screens/timer/components/timeline/widget_timeline_timer.dart';
|
import 'package:lightmeter/screens/timer/components/timeline/widget_timeline_timer.dart';
|
||||||
import 'package:lightmeter/screens/timer/event_timer.dart';
|
import 'package:lightmeter/screens/timer/event_timer.dart';
|
||||||
|
@ -64,69 +65,55 @@ class _TimerScreenState extends State<TimerScreen> with TickerProviderStateMixin
|
||||||
listenWhen: (previous, current) => previous.runtimeType != current.runtimeType,
|
listenWhen: (previous, current) => previous.runtimeType != current.runtimeType,
|
||||||
listener: (context, state) => _updateAnimations(state),
|
listener: (context, state) => _updateAnimations(state),
|
||||||
child: Scaffold(
|
child: Scaffold(
|
||||||
appBar: AppBar(
|
body: Center(
|
||||||
automaticallyImplyLeading: false,
|
child: Column(
|
||||||
centerTitle: true,
|
mainAxisAlignment: MainAxisAlignment.center,
|
||||||
elevation: 0,
|
children: [
|
||||||
title: Text(
|
TimerMeteringConfig(exposurePair: widget.exposurePair),
|
||||||
widget.exposurePair.toString(),
|
const Spacer(),
|
||||||
style: TextStyle(
|
Padding(
|
||||||
color: Theme.of(context).colorScheme.onSurface,
|
padding: const EdgeInsets.all(Dimens.paddingL),
|
||||||
fontSize: Dimens.grid24,
|
child: SizedBox.fromSize(
|
||||||
),
|
size: Size.square(MediaQuery.sizeOf(context).width - Dimens.paddingL * 4),
|
||||||
),
|
child: ValueListenableBuilder(
|
||||||
),
|
valueListenable: timelineAnimation,
|
||||||
body: SafeArea(
|
builder: (_, value, child) => TimerTimeline(
|
||||||
bottom: false,
|
progress: value,
|
||||||
child: Center(
|
child: TimerText(
|
||||||
child: Column(
|
timeLeft: Duration(milliseconds: (widget.duration.inMilliseconds * value).toInt()),
|
||||||
mainAxisAlignment: MainAxisAlignment.center,
|
duration: widget.duration,
|
||||||
children: [
|
|
||||||
const Spacer(),
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.all(Dimens.paddingL),
|
|
||||||
child: SizedBox.fromSize(
|
|
||||||
size: Size.square(MediaQuery.sizeOf(context).width - Dimens.paddingL * 4),
|
|
||||||
child: ValueListenableBuilder(
|
|
||||||
valueListenable: timelineAnimation,
|
|
||||||
builder: (_, value, child) => TimerTimeline(
|
|
||||||
progress: value,
|
|
||||||
child: TimerText(
|
|
||||||
timeLeft: Duration(milliseconds: (widget.duration.inMilliseconds * value).toInt()),
|
|
||||||
duration: widget.duration,
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
const Spacer(),
|
),
|
||||||
BottomControlsBar(
|
const Spacer(),
|
||||||
left: IconButton(
|
BottomControlsBar(
|
||||||
|
left: IconButton(
|
||||||
|
onPressed: () {
|
||||||
|
context.read<TimerBloc>().add(const ResetTimerEvent());
|
||||||
|
},
|
||||||
|
icon: const Icon(Icons.restore),
|
||||||
|
),
|
||||||
|
center: BlocBuilder<TimerBloc, TimerState>(
|
||||||
|
builder: (_, state) => FloatingActionButton(
|
||||||
|
shape: state is TimerResumedState ? null : const CircleBorder(),
|
||||||
onPressed: () {
|
onPressed: () {
|
||||||
context.read<TimerBloc>().add(const ResetTimerEvent());
|
if (timelineAnimation.value == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final event = state is TimerStoppedState ? const StartTimerEvent() : const StopTimerEvent();
|
||||||
|
context.read<TimerBloc>().add(event);
|
||||||
},
|
},
|
||||||
icon: const Icon(Icons.restore),
|
child: AnimatedIcon(
|
||||||
),
|
icon: AnimatedIcons.play_pause,
|
||||||
center: BlocBuilder<TimerBloc, TimerState>(
|
progress: startStopIconAnimation,
|
||||||
builder: (_, state) => FloatingActionButton(
|
|
||||||
shape: state is TimerResumedState ? null : const CircleBorder(),
|
|
||||||
onPressed: () {
|
|
||||||
if (timelineAnimation.value == 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
final event = state is TimerStoppedState ? const StartTimerEvent() : const StopTimerEvent();
|
|
||||||
context.read<TimerBloc>().add(event);
|
|
||||||
},
|
|
||||||
child: AnimatedIcon(
|
|
||||||
icon: AnimatedIcons.play_pause,
|
|
||||||
progress: startStopIconAnimation,
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
right: Navigator.of(context).canPop() ? const CloseButton() : null,
|
|
||||||
),
|
),
|
||||||
],
|
right: Navigator.of(context).canPop() ? const CloseButton() : null,
|
||||||
),
|
),
|
||||||
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
|
Loading…
Reference in a new issue