mirror of
https://gitlab.com/nkming2/nc-photos.git
synced 2025-01-23 17:26:18 +01:00
105 lines
2.9 KiB
Dart
105 lines
2.9 KiB
Dart
import 'dart:async';
|
|
|
|
import 'package:flutter/services.dart';
|
|
import 'package:flutter/widgets.dart';
|
|
import 'package:logging/logging.dart';
|
|
import 'package:native_device_orientation/native_device_orientation.dart';
|
|
import 'package:nc_photos/platform/k.dart' as platform_k;
|
|
import 'package:nc_photos/pref.dart';
|
|
import 'package:nc_photos/widget/disposable.dart';
|
|
import 'package:screen_brightness/screen_brightness.dart';
|
|
|
|
mixin ViewerControllersMixin<T extends StatefulWidget>
|
|
on DisposableManagerMixin<T> {
|
|
@override
|
|
initDisposables() {
|
|
return [
|
|
...super.initDisposables(),
|
|
if (platform_k.isMobile) _ViewerBrightnessController(),
|
|
_ViewerSystemUiResetter(),
|
|
if (platform_k.isMobile && Pref.inst().isViewerForceRotationOr(false))
|
|
_ViewerOrientationController(
|
|
onChanged: _onOrientationChanged,
|
|
),
|
|
];
|
|
}
|
|
|
|
void _onOrientationChanged(NativeDeviceOrientation orientation) {
|
|
_log.info("[_onOrientationChanged] $orientation");
|
|
if (!mounted) {
|
|
return;
|
|
}
|
|
final List<DeviceOrientation> prefer;
|
|
switch (orientation) {
|
|
case NativeDeviceOrientation.portraitDown:
|
|
prefer = [DeviceOrientation.portraitDown];
|
|
break;
|
|
case NativeDeviceOrientation.landscapeLeft:
|
|
prefer = [DeviceOrientation.landscapeLeft];
|
|
break;
|
|
|
|
case NativeDeviceOrientation.landscapeRight:
|
|
prefer = [DeviceOrientation.landscapeRight];
|
|
break;
|
|
|
|
case NativeDeviceOrientation.portraitUp:
|
|
default:
|
|
prefer = [DeviceOrientation.portraitUp];
|
|
break;
|
|
}
|
|
SystemChrome.setPreferredOrientations(prefer);
|
|
}
|
|
|
|
static final _log = Logger("widget.viewer_mixin.ViewerControllersMixin");
|
|
}
|
|
|
|
/// Control the screen brightness according to the settings
|
|
class _ViewerBrightnessController implements Disposable {
|
|
@override
|
|
init(State state) {
|
|
final brightness = Pref.inst().getViewerScreenBrightness();
|
|
if (brightness != null && brightness >= 0) {
|
|
ScreenBrightness.setScreenBrightness(brightness / 100.0);
|
|
}
|
|
}
|
|
|
|
@override
|
|
dispose(State state) {
|
|
ScreenBrightness.resetScreenBrightness();
|
|
}
|
|
}
|
|
|
|
/// Make sure the system UI overlay is reset on dispose
|
|
class _ViewerSystemUiResetter implements Disposable {
|
|
@override
|
|
init(State state) {}
|
|
|
|
@override
|
|
dispose(State state) {
|
|
SystemChrome.setEnabledSystemUIOverlays(SystemUiOverlay.values);
|
|
}
|
|
}
|
|
|
|
class _ViewerOrientationController implements Disposable {
|
|
_ViewerOrientationController({
|
|
this.onChanged,
|
|
});
|
|
|
|
@override
|
|
init(State state) {
|
|
_subscription = NativeDeviceOrientationCommunicator()
|
|
.onOrientationChanged(useSensor: true)
|
|
.listen((orientation) {
|
|
onChanged?.call(orientation);
|
|
});
|
|
}
|
|
|
|
@override
|
|
dispose(State state) {
|
|
_subscription.cancel();
|
|
SystemChrome.setPreferredOrientations([]);
|
|
}
|
|
|
|
ValueChanged<NativeDeviceOrientation>? onChanged;
|
|
late final StreamSubscription<NativeDeviceOrientation> _subscription;
|
|
}
|