2022-10-24 20:25:38 +00:00
|
|
|
import 'package:flutter/material.dart';
|
2022-10-29 18:02:45 +00:00
|
|
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
2022-12-18 09:03:41 +00:00
|
|
|
import 'package:lightmeter/data/models/photography_values/photography_value.dart';
|
2022-10-29 18:02:45 +00:00
|
|
|
import 'package:lightmeter/res/dimens.dart';
|
2022-12-18 09:03:41 +00:00
|
|
|
import 'package:lightmeter/screens/settings/screen_settings.dart';
|
2022-10-24 20:25:38 +00:00
|
|
|
|
2022-12-18 09:03:41 +00:00
|
|
|
import 'components/bottom_controls/widget_bottom_controls.dart';
|
2022-12-21 19:31:22 +00:00
|
|
|
import 'components/camera/widget_exposure_slider.dart';
|
|
|
|
import 'components/camera/widget_zoom_camera.dart';
|
2022-12-18 09:03:41 +00:00
|
|
|
import 'components/exposure_pairs_list/widget_list_exposure_pairs.dart';
|
|
|
|
import 'components/topbar/widget_topbar.dart';
|
2022-12-14 17:33:38 +00:00
|
|
|
import 'bloc_metering.dart';
|
|
|
|
import 'event_metering.dart';
|
|
|
|
import 'state_metering.dart';
|
2022-10-24 20:25:38 +00:00
|
|
|
|
2022-11-26 18:14:51 +00:00
|
|
|
class MeteringScreen extends StatefulWidget {
|
2022-12-11 14:09:10 +00:00
|
|
|
const MeteringScreen({super.key});
|
2022-10-24 20:25:38 +00:00
|
|
|
|
2022-11-26 18:14:51 +00:00
|
|
|
@override
|
|
|
|
State<MeteringScreen> createState() => _MeteringScreenState();
|
|
|
|
}
|
|
|
|
|
2022-11-26 19:29:00 +00:00
|
|
|
class _MeteringScreenState extends State<MeteringScreen> {
|
2023-01-20 19:31:35 +00:00
|
|
|
double topBarOverflow = 0.0;
|
|
|
|
|
2022-12-11 14:04:08 +00:00
|
|
|
@override
|
|
|
|
void didChangeDependencies() {
|
|
|
|
super.didChangeDependencies();
|
|
|
|
context.read<MeteringBloc>().add(StopTypeChangedEvent(context.watch<StopType>()));
|
|
|
|
}
|
|
|
|
|
2022-10-24 20:25:38 +00:00
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Scaffold(
|
|
|
|
backgroundColor: Theme.of(context).colorScheme.background,
|
2022-10-29 18:02:45 +00:00
|
|
|
body: BlocBuilder<MeteringBloc, MeteringState>(
|
|
|
|
builder: (context, state) {
|
2022-11-26 18:14:51 +00:00
|
|
|
return Stack(
|
2022-10-29 18:02:45 +00:00
|
|
|
children: [
|
2022-11-26 18:14:51 +00:00
|
|
|
Column(
|
|
|
|
children: [
|
2023-01-20 19:31:35 +00:00
|
|
|
MeteringTopBar(
|
|
|
|
fastest: state.fastest,
|
|
|
|
slowest: state.slowest,
|
|
|
|
ev: state.ev,
|
|
|
|
iso: state.iso,
|
|
|
|
nd: state.nd,
|
|
|
|
onIsoChanged: (value) => context.read<MeteringBloc>().add(IsoChangedEvent(value)),
|
|
|
|
onNdChanged: (value) => context.read<MeteringBloc>().add(NdChangedEvent(value)),
|
|
|
|
onCutoutLayout: (value) => topBarOverflow = value,
|
|
|
|
),
|
2022-11-26 18:14:51 +00:00
|
|
|
Expanded(
|
2023-01-20 19:31:35 +00:00
|
|
|
child: LayoutBuilder(
|
|
|
|
builder: (context, constraints) => OverflowBox(
|
|
|
|
alignment: Alignment.bottomCenter,
|
|
|
|
maxHeight: constraints.maxHeight + topBarOverflow.abs(),
|
|
|
|
maxWidth: constraints.maxWidth,
|
|
|
|
child: Padding(
|
|
|
|
padding: const EdgeInsets.symmetric(horizontal: Dimens.paddingM),
|
|
|
|
child: Row(
|
|
|
|
children: [
|
|
|
|
Expanded(
|
|
|
|
child: Padding(
|
|
|
|
padding: topBarOverflow >= 0 ? EdgeInsets.only(top: topBarOverflow) : EdgeInsets.zero,
|
|
|
|
child: ExposurePairsList(state.exposurePairs),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
const SizedBox(width: Dimens.grid8),
|
|
|
|
Expanded(
|
|
|
|
child: Padding(
|
|
|
|
padding: const EdgeInsets.symmetric(vertical: Dimens.paddingM).add(
|
|
|
|
topBarOverflow <= 0 ? EdgeInsets.only(top: -topBarOverflow) : EdgeInsets.zero),
|
|
|
|
child: Column(
|
|
|
|
children: const [
|
|
|
|
Expanded(child: CameraExposureSlider()),
|
|
|
|
SizedBox(height: Dimens.grid24),
|
|
|
|
CameraZoomSlider(),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
2022-12-21 19:31:22 +00:00
|
|
|
),
|
2023-01-20 19:31:35 +00:00
|
|
|
],
|
2022-12-21 19:31:22 +00:00
|
|
|
),
|
2023-01-20 19:31:35 +00:00
|
|
|
),
|
2022-10-29 18:02:45 +00:00
|
|
|
),
|
2022-11-26 18:14:51 +00:00
|
|
|
),
|
2022-10-29 18:02:45 +00:00
|
|
|
),
|
2023-01-20 19:31:35 +00:00
|
|
|
MeteringBottomControls(
|
|
|
|
onMeasure: () => context.read<MeteringBloc>().add(const MeasureEvent()),
|
|
|
|
onSettings: () {
|
|
|
|
Navigator.push(context, MaterialPageRoute(builder: (context) => const SettingsScreen()));
|
|
|
|
},
|
|
|
|
),
|
2022-11-26 18:14:51 +00:00
|
|
|
],
|
2022-10-29 18:02:45 +00:00
|
|
|
),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
},
|
2022-10-24 20:25:38 +00:00
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|