| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- import 'package:flutter_map/flutter_map.dart';
- import 'package:flutter_screenutil/flutter_screenutil.dart';
- import 'package:get/get.dart';
- import 'package:get/get_core/src/get_main.dart';
- import 'package:injectable/injectable.dart';
- import 'package:location/base/base_controller.dart';
- import 'package:location/data/bean/location_info.dart';
- import 'package:location/data/bean/track_days.dart';
- import 'package:location/data/repositories/account_repository.dart';
- import 'package:location/data/repositories/friends_repository.dart';
- import 'package:location/data/repositories/track_repository.dart';
- import 'package:location/handler/error_handler.dart';
- import 'package:sliding_sheet2/sliding_sheet2.dart';
- import '../../data/bean/atmob_track_point.dart';
- import '../../data/bean/user_info.dart';
- @injectable
- class TrackController extends BaseController {
- final Rxn<UserInfo> _userInfo = Rxn<UserInfo>();
- UserInfo? get userInfo => _userInfo.value;
- final MapController mapController = MapController();
- SheetController sheetController = SheetController();
- final RxList<TrackDays> daysList = RxList<TrackDays>();
- final TrackRepository trackRepository;
- final FriendsRepository friendsRepository;
- final AccountRepository accountRepository;
- TrackController(
- this.trackRepository, this.friendsRepository, this.accountRepository);
- @override
- void onInit() {
- final param = Get.arguments;
- if (param is UserInfo) {
- _userInfo.value = param;
- }
- _onRequestTrackDateList();
- }
- @override
- void onReady() {
- super.onReady();
- sheetController.expand();
- _recordNumberTrajectoryViewed();
- }
- void _onRequestTrackDateList() {
- trackRepository.getLocationTrackDays().then((list) {
- daysList.assignAll(list);
- }).catchError((error) {
- ErrorHandler.toastError(error);
- });
- }
- ///记录查看轨迹的次数
- void _recordNumberTrajectoryViewed() {
- if (accountRepository.memberStatusInfo.value?.trialed == true &&
- accountRepository.memberStatusInfo.value?.level == 20) {
- trackRepository.refreshMemberTrailTrack();
- }
- }
- ///显示轨迹以及标记点
- void showMapTrack(List<LatLng> points, List<Marker> markers) {
- mapController.clear();
- //画折线
- if (points.length > 1) {
- mapController.addPolyline(points,
- mapPadding: MapPadding(
- left: 50.w, top: 100.w, right: 50.w, bottom: Get.height / 2));
- }
- //画标记点
- if (markers.isNotEmpty) {
- mapController.updateOrAddMarkers(markers);
- }
- }
- void back() {
- Get.back();
- }
- }
|