123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336 |
- part of 'operate_bar.dart';
- class _ContrastToneBar extends StatefulWidget {
- @override
- State<StatefulWidget> createState() => _ContrastToneBarState();
- }
- class _ContrastToneBarState extends State<_ContrastToneBar> {
- late final measureController = Get.find<MeasureController>();
- VidPlayerController playerController =
- Get.find<IPlayerController>() as VidPlayerController;
- ///屏幕缩放比例
- double get devicePixelRatio =>
- kIsMobile ? 1 : MediaQuery.of(context).devicePixelRatio;
- double curValue = 0;
- @override
- void initState() {
- WidgetsBinding.instance.addPostFrameCallback((timeStamp) {
- if (mounted) {
- playerController.eventHandler.addListener(onControllerEvent);
- measureController.imageLoaded.addListener(updatePlayerController);
- }
- });
- super.initState();
- }
- /// 更新 controller
- void updatePlayerController(a, b) {
- playerController.eventHandler.removeListener(onControllerEvent);
- playerController = Get.find<IPlayerController>() as VidPlayerController;
- playerController.eventHandler.addListener(onControllerEvent);
- }
- @override
- Widget build(BuildContext context) {
- return _ToneBar(
- max: 100,
- min: -100,
- value: curValue,
- icon: Icon(
- Icons.contrast,
- color: Colors.white,
- size: 24 / devicePixelRatio,
- ),
- onChange: (v) {
- playerController.setContrast(v.toInt());
- },
- );
- }
- @override
- void dispose() {
- playerController.eventHandler.removeListener(onControllerEvent);
- measureController.imageLoaded.removeListener(updatePlayerController);
- super.dispose();
- }
- void onControllerEvent(Object sender, VidPlayerEvent e) {
- if (e is VidPlayResetToneEvent) {
- onResetTone();
- }
- }
- void onResetTone() {
- setState(() {
- curValue = 0;
- });
- }
- }
- class _BrightnessToneBar extends StatefulWidget {
- @override
- State<StatefulWidget> createState() => _BrightnessToneBarState();
- }
- class _BrightnessToneBarState extends State<_BrightnessToneBar> {
- late final measureController = Get.find<MeasureController>();
- VidPlayerController playerController =
- Get.find<IPlayerController>() as VidPlayerController;
- ///屏幕缩放比例
- double get devicePixelRatio =>
- kIsMobile ? 1 : MediaQuery.of(context).devicePixelRatio;
- double curValue = 0;
- @override
- void initState() {
- WidgetsBinding.instance.addPostFrameCallback((timeStamp) {
- if (mounted) {
- playerController.eventHandler.addListener(onControllerEvent);
- measureController.imageLoaded.addListener(updatePlayerController);
- }
- });
- super.initState();
- }
- /// 更新 controller
- void updatePlayerController(a, b) {
- playerController.eventHandler.removeListener(onControllerEvent);
- playerController = Get.find<IPlayerController>() as VidPlayerController;
- playerController.eventHandler.addListener(onControllerEvent);
- }
- @override
- Widget build(BuildContext context) {
- return _ToneBar(
- max: 100,
- min: -100,
- value: curValue,
- icon: Icon(
- Icons.wb_sunny_sharp,
- color: Colors.white,
- size: 24 / devicePixelRatio,
- ),
- onChange: (v) {
- playerController.setBrightness(v.toInt());
- },
- );
- }
- @override
- void dispose() {
- playerController.eventHandler.removeListener(onControllerEvent);
- measureController.imageLoaded.removeListener(updatePlayerController);
- super.dispose();
- }
- void onControllerEvent(Object sender, VidPlayerEvent e) {
- if (e is VidPlayResetToneEvent) {
- onResetTone();
- }
- }
- void onResetTone() {
- setState(() {
- curValue = 0;
- });
- }
- }
- class _ToneBar extends StatefulWidget {
- const _ToneBar({
- Key? key,
- required this.icon,
- required this.min,
- required this.max,
- required this.value,
- this.onChange,
- }) : super(key: key);
- final Widget icon;
- final ValueChanged<double>? onChange;
- final double min;
- final double max;
- final double value;
- final Color themeColor = Colors.white;
- @override
- State<StatefulWidget> createState() => _ToneBarState();
- }
- class _ToneBarState extends State<_ToneBar> {
- double get _kIconSize => 20.0 / devicePixelRatio;
- double get splashRadius => _kIconSize / 2 + 3;
- double get devicePixelRatio =>
- kIsMobile ? 1 : MediaQuery.of(context).devicePixelRatio;
- late double _value;
- @override
- void initState() {
- syncProps();
- super.initState();
- }
- @override
- void didUpdateWidget(covariant _ToneBar oldWidget) {
- syncProps();
- super.didUpdateWidget(oldWidget);
- }
- void syncProps() {
- _value = widget.value;
- }
- @override
- Widget build(BuildContext context) {
- return Row(
- mainAxisAlignment: MainAxisAlignment.center,
- children: [
- widget.icon,
- const SizedBox(width: 8),
- buildReduceIcon(),
- buildSlider(context),
- buildIncreaseIcon(),
- const SizedBox(width: 8),
- SizedBox(
- width: 30 / devicePixelRatio,
- child: Text(
- '${_value.toInt()}',
- style: TextStyle(color: widget.themeColor),
- )),
- ],
- );
- }
- Widget buildReduceIcon() {
- return IconButton(
- color: widget.themeColor,
- constraints: BoxConstraints(
- minHeight: _kIconSize,
- minWidth: _kIconSize,
- ),
- splashRadius: splashRadius,
- padding: EdgeInsets.zero,
- onPressed: () {
- updateValue(_value - 1);
- },
- icon: Icon(Icons.remove_circle_outline, size: _kIconSize),
- );
- }
- Widget buildIncreaseIcon() {
- return IconButton(
- color: widget.themeColor,
- constraints: BoxConstraints(
- minHeight: _kIconSize,
- minWidth: _kIconSize,
- ),
- splashRadius: splashRadius,
- padding: EdgeInsets.zero,
- onPressed: () {
- updateValue(_value + 1);
- },
- icon: Icon(Icons.add_circle_outline, size: _kIconSize),
- );
- }
- Widget buildSlider(BuildContext context) {
- final trackColor = Theme.of(context).primaryColor;
- return Expanded(
- child: SliderTheme(
- data: SliderThemeData(
- trackHeight: 4,
- activeTrackColor: trackColor,
- inactiveTrackColor: trackColor,
- thumbColor: Colors.grey[300],
- thumbShape: const RoundSliderThumbShape(
- enabledThumbRadius: 6,
- elevation: 3.0,
- ),
- overlayShape: SliderComponentShape.noOverlay,
- trackShape: _FullWidthRectangularSliderTrackShape(
- padding: const EdgeInsets.symmetric(horizontal: 4),
- devicePixelRatio: devicePixelRatio,
- ),
- ),
- child: Slider(
- max: widget.max,
- min: widget.min,
- value: _value,
- label: _value.toInt().toString(),
- divisions: (widget.max - widget.min).toInt(),
- onChanged: (v) {
- updateValue(v);
- },
- ),
- ),
- );
- }
- void updateValue(double value) {
- if (value < widget.min || value > widget.max) {
- return;
- }
- setState(() {
- _value = value;
- });
- widget.onChange?.call(value);
- }
- }
- class _FullWidthRectangularSliderTrackShape
- extends RectangularSliderTrackShape {
- const _FullWidthRectangularSliderTrackShape({
- this.padding,
- this.devicePixelRatio = 1,
- });
- final EdgeInsets? padding;
- final double devicePixelRatio;
- @override
- Rect getPreferredRect({
- required RenderBox parentBox,
- Offset offset = Offset.zero,
- required SliderThemeData sliderTheme,
- bool isEnabled = false,
- bool isDiscrete = false,
- }) {
- double trackHeight = sliderTheme.trackHeight ?? 2;
- double trackLeft = offset.dx;
- double trackTop = offset.dy + (parentBox.size.height - trackHeight) / 2;
- // 让轨道宽度等于 Slider 宽度
- double trackWidth = parentBox.size.width;
- if (padding != null) {
- trackHeight -= padding!.bottom;
- trackHeight -= padding!.top;
- trackWidth -= padding!.right;
- trackWidth -= padding!.left;
- trackTop += padding!.top;
- trackLeft += padding!.left;
- }
- return Rect.fromLTWH(trackLeft, trackTop, trackWidth, trackHeight);
- }
- }
- class _ResetToneButton extends StatelessWidget {
- @override
- Widget build(BuildContext context) {
- return ElevatedButton(
- onPressed: () {
- final playerController =
- Get.find<IPlayerController>() as VidPlayerController;
- playerController.resetTone();
- },
- child: Text(
- i18nBook.measure.resetTone4Btn.t,
- style: const TextStyle(
- color: Colors.white,
- fontSize: 16,
- ),
- ),
- );
- }
- }
|