Lightmeter app inspired by Material 3 design system.
Find a file
Vadim 5c27f726c5
ML-173 Add a timer for long exposures (#174)
* wip

* added start/stop button

* animated timeline

* fixed timer stop state

* added reset button (wip)

* added `onExposurePairTap` callback

* integrated `TimerScreen` to navigation

* separated `TimerTimeline`

* fixed timeline flickering

* added milliseconds to timer

* synchronized timeline with actual timer

* reused `BottomControlsBar`

* fixed default scaffold background color

* moved center button size to the bar itself

* display selected exposure pair on timer screen

* separated reusable `AnimatedCircluarButton`

* release camera when timer is opened

* added `TimerInteractor`

* added `TimerBloc` test

* fixed hours parsing

* added scenarios for timer golden test

* adjusted timer timeline colors

* show iso & nd values on timer screen

* automatically close timer screen after timeout

* added timer autostart

* reverted theme changes

* updated goldens

* typo

* removed timer screen auto-dismiss

* increased timer vibration duration

* replaced outlined locks

* increased 1/3 values font size
2024-05-07 19:24:51 +02:00
.github Fixed release creation workflow 2024-04-19 17:03:45 +02:00
.vscode ML-44 Save zoom level for equipment profile (#164) 2024-04-07 10:54:57 +02:00
android ML-160 Integration tests (#161) 2024-03-13 15:34:26 +01:00
assets Add app icon indicating dev build (#139) 2023-11-21 21:37:23 +01:00
doc Added GP resources 2023-04-08 17:27:04 +03:00
iap ML-170 Show long shutter speeds for all selected aperture values (#172) 2024-04-30 12:44:01 +02:00
integration_test ML-173 Add a timer for long exposures (#174) 2024-05-07 19:24:51 +02:00
ios ML-157 Improve CI/CD (#162) 2024-03-17 20:04:27 +01:00
lib ML-173 Add a timer for long exposures (#174) 2024-05-07 19:24:51 +02:00
resources ML-11 Implement volume buttons actions (#86) 2023-07-09 13:39:33 +02:00
screenshots ML-170 Show long shutter speeds for all selected aperture values (#172) 2024-04-30 12:44:01 +02:00
test ML-173 Add a timer for long exposures (#174) 2024-05-07 19:24:51 +02:00
test_driver ML-108 First exposure metering seems to be wrong (#163) 2024-04-06 19:14:37 +02:00
.gitignore ML-166 Golden tests (#167) 2024-04-12 08:07:20 +02:00
.metadata init project 2022-10-15 19:35:35 +03:00
analysis_options.yaml ML-62 Interactors tests (#87) 2023-07-10 17:49:34 +02:00
crowdin.yml Push new localization strings to Crowdin (#30) 2023-02-12 13:09:55 +03:00
dart_test.yaml ML-166 Golden tests (#167) 2024-04-12 08:07:20 +02:00
LICENSE Initial commit 2022-10-15 16:00:14 +03:00
m3_lightmeter.code-workspace ML-107 Films filter (#118) 2023-09-14 16:59:16 +02:00
PRIVACY_POLICY.md Update PRIVACY_POLICY.md 2024-01-04 16:52:56 +01:00
pubspec.yaml ML-170 Show long shutter speeds for all selected aperture values (#172) 2024-04-30 12:44:01 +02:00
README.md ML-108 First exposure metering seems to be wrong (#163) 2024-04-06 19:14:37 +02:00
test_coverage.sh Fixed test coverage script 2024-03-17 20:18:00 +01:00
update_goldens.sh ML-166 Fixed golden tests run on CI (#168) 2024-04-12 10:43:19 +02:00

Table of contents

Backstory

Some time ago I've started developing the Material Lightmeter app. Unfortunately, the last update of this app was almost a year prior to creation of this repo. So after reading some positive review on Google Play saying that "this is an excellent app, too bad it is no longer updated", I've decided to make an update and also make this app open source. Maybe someone sometime will decide to contribute to this project.

But as the existing repo contained some sensitive data, that I've pushed due to lack of experience, I had to make a new one. And if creating a new repo, why not rewrite the app from scratch?

Without further delay behold my new Lightmeter app inspired by Material You (a.k.a. M3)

Screenshots

Development

1. Install Flutter

To build this app you need to install Flutter 3.13.9 stable. How to install.

2. Project setup

Restore constants.dart file

Create a file lib/constants.dart and paste the following content:

const String contactEmail = '';
const String iapServerUrl = '';
const String issuesReportUrl = '';
const String sourceCodeUrl = '';

Stub IAP package

As part of the app's functionallity is in the private repo, you have to replace these lines in pubspec.yaml:

m3_lightmeter_iap:
  git:
    url: "https://github.com/vodemn/m3_lightmeter_iap"
    ref: main

with these:

m3_lightmeter_iap:
  path: iap

You can do it simply by running the script:

sh .github/scripts/stub_iap.sh

If you are using VSCode, you can open the workspace like so: File -> Open Workspace from File -> m3_lightmeter.code-workspace. Otherwise you have to run flutter pub get command from the iap folder.

Then you can fetch all the neccessary dependencies and generate translation files by running the following commands:

flutter pub get
flutter pub run intl_utils:generate

3. (Optional) Install Firebase

Out of the box Firebase Crashlytics won't work. If you want to add Crashlytics to your local build please follow this guide.

4. Build

Support

To report a bug or suggest a new feature open a new issue. To contribute to the project feel free to open a Pull Request, but you need to follow this style guide.

In case you have any other questions please contact me via email.

iOS Limitations

A list of features, that Android version of the app has and that iOS does not.

Incident light metering

Apple does not provide API for reading Lux stream form the ambient light sensor. Lux can be calculated based on front camera image stream, but this would be a reflected light. So there is no way incident light metering can be implemented on iOS.

Volume buttons action

This can be implemented but the app will be rejected due to 2.5.9