forked from Elara6331/infinitime
		
	Compare commits
	
		
			9 Commits
		
	
	
		
			54fdd19bec
			...
			navigation
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | c3a87278a6 | ||
|  | d46f5453f6 | ||
|  | e00a4fce70 | ||
|  | 49544b9b47 | ||
|  | e6a1baa32b | ||
|  | ba3169d1d0 | ||
|  | 912ccd14b3 | ||
|  | 62987fa31b | ||
|  | 2fbd8cb666 | 
| @@ -47,6 +47,7 @@ This library currently supports the following features: | |||||||
| - Battery level | - Battery level | ||||||
| - Music control | - Music control | ||||||
| - OTA firmware upgrades | - OTA firmware upgrades | ||||||
|  | - Navigation | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
|   | |||||||
| @@ -52,6 +52,10 @@ var charNames = map[string]string{ | |||||||
| 	FSTransferChar:  "Filesystem Transfer", | 	FSTransferChar:  "Filesystem Transfer", | ||||||
| 	FSVersionChar:   "Filesystem Version", | 	FSVersionChar:   "Filesystem Version", | ||||||
| 	WeatherDataChar: "Weather Data", | 	WeatherDataChar: "Weather Data", | ||||||
|  | 	NavFlagsChar:    "Navigation Icon", | ||||||
|  | 	NavNarrativeChar:"Navigation Instruction", | ||||||
|  | 	NavManDistChar:  "Navigation Distance to next event", | ||||||
|  | 	NavProgressChar: "Navigation Progress", | ||||||
| } | } | ||||||
|  |  | ||||||
| type Device struct { | type Device struct { | ||||||
| @@ -67,10 +71,13 @@ type Device struct { | |||||||
| 	fsVersionChar   *gatt.GattCharacteristic1 | 	fsVersionChar   *gatt.GattCharacteristic1 | ||||||
| 	fsTransferChar  *gatt.GattCharacteristic1 | 	fsTransferChar  *gatt.GattCharacteristic1 | ||||||
| 	weatherDataChar *gatt.GattCharacteristic1 | 	weatherDataChar *gatt.GattCharacteristic1 | ||||||
|  | 	weatherdataChar *gatt.GattCharacteristic1 | ||||||
| 	notifEventCh    chan uint8 | 	notifEventCh    chan uint8 | ||||||
| 	notifEventDone  bool | 	notifEventDone  bool | ||||||
| 	Music           MusicCtrl | 	Music           MusicCtrl | ||||||
|  | 	Navigation      NavigationCtrl | ||||||
| 	DFU             DFU | 	DFU             DFU | ||||||
|  | 	navigationEv    NavigationEvent | ||||||
| } | } | ||||||
|  |  | ||||||
| var ( | var ( | ||||||
| @@ -394,6 +401,14 @@ func (i *Device) resolveChars() error { | |||||||
| 		charResolved := true | 		charResolved := true | ||||||
| 		// Set correct characteristics | 		// Set correct characteristics | ||||||
| 		switch char.Properties.UUID { | 		switch char.Properties.UUID { | ||||||
|  | 		case NavFlagsChar: | ||||||
|  | 			i.Navigation.flagsChar = char | ||||||
|  | 		case NavNarrativeChar: | ||||||
|  | 			i.Navigation.narrativeChar = char | ||||||
|  | 		case NavManDistChar: | ||||||
|  | 			i.Navigation.mandistChar = char | ||||||
|  | 		case NavProgressChar: | ||||||
|  | 			i.Navigation.progressChar = char | ||||||
| 		case NewAlertChar: | 		case NewAlertChar: | ||||||
| 			i.newAlertChar = char | 			i.newAlertChar = char | ||||||
| 		case NotifEventChar: | 		case NotifEventChar: | ||||||
| @@ -723,6 +738,7 @@ func (i *Device) Notify(title, body string) error { | |||||||
| 	) | 	) | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| // These constants represent the possible call statuses selected by the user | // These constants represent the possible call statuses selected by the user | ||||||
| const ( | const ( | ||||||
| 	CallStatusDeclined uint8 = iota | 	CallStatusDeclined uint8 = iota | ||||||
|   | |||||||
							
								
								
									
										188
									
								
								navigation.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										188
									
								
								navigation.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,188 @@ | |||||||
|  | package infinitime | ||||||
|  |  | ||||||
|  | import ( | ||||||
|  | 	"bytes" | ||||||
|  | 	"encoding/binary" | ||||||
|  | 	"errors" | ||||||
|  | 	"github.com/muka/go-bluetooth/bluez/profile/gatt" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | const ( | ||||||
|  | 	NavFlagsChar    = "00010001-78fc-48fe-8e23-433b3a1942d0" | ||||||
|  | 	NavNarrativeChar= "00010002-78fc-48fe-8e23-433b3a1942d0" | ||||||
|  | 	NavManDistChar  = "00010003-78fc-48fe-8e23-433b3a1942d0" | ||||||
|  | 	NavProgressChar = "00010004-78fc-48fe-8e23-433b3a1942d0" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | type NavigationCtrl struct { | ||||||
|  | 	flagsChar    *gatt.GattCharacteristic1 | ||||||
|  | 	narrativeChar*gatt.GattCharacteristic1 | ||||||
|  | 	mandistChar  *gatt.GattCharacteristic1 | ||||||
|  | 	progressChar *gatt.GattCharacteristic1 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type NavFlag string | ||||||
|  | const ( | ||||||
|  | 	NavFlagArrive                  NavFlag = "arrive" | ||||||
|  | 	NavFlagArriveLeft              NavFlag = "arrive-left" | ||||||
|  | 	NavFlagArriveRight             NavFlag = "arrive-right" | ||||||
|  | 	NavFlagArriveStraight          NavFlag = "arrive-straight" | ||||||
|  | 	NavFlagClose                   NavFlag = "close" | ||||||
|  | 	NavFlagContinue                NavFlag = "continue" | ||||||
|  | 	NavFlagContinueLeft            NavFlag = "continue-left" | ||||||
|  | 	NavFlagContinueRight           NavFlag = "continue-right" | ||||||
|  | 	NavFlagContinueSlightLeft      NavFlag = "continue-slight-left" | ||||||
|  | 	NavFlagContinueSlightRight     NavFlag = "continue-slight-right" | ||||||
|  | 	NavFlagContinueStraight        NavFlag = "continue-straight" | ||||||
|  | 	NavFlagContinueUturn           NavFlag = "continue-uturn" | ||||||
|  | 	NavFlagDepart                  NavFlag = "depart" | ||||||
|  | 	NavFlagDepartLeft              NavFlag = "depart-left" | ||||||
|  | 	NavFlagDepartRight             NavFlag = "depart-right" | ||||||
|  | 	NavFlagDepartStraight          NavFlag = "depart-straight" | ||||||
|  | 	NavFlagEndOfRoadLeft           NavFlag = "end-of-road-left" | ||||||
|  | 	NavFlagEndOfRoadRight          NavFlag = "end-of-road-right" | ||||||
|  | 	NavFlagFerry                   NavFlag = "ferry" | ||||||
|  | 	NavFlagFlag                    NavFlag = "flag" | ||||||
|  | 	NavFlagFork                    NavFlag = "fork" | ||||||
|  | 	NavFlagForkLeft                NavFlag = "fork-left" | ||||||
|  | 	NavFlagForkRight               NavFlag = "fork-right" | ||||||
|  | 	NavFlagForkSlightLeft          NavFlag = "fork-slight-left" | ||||||
|  | 	NavFlagForkSlightRight         NavFlag = "fork-slight-right" | ||||||
|  | 	NavFlagForkStraight            NavFlag = "fork-straight" | ||||||
|  | 	NavFlagInvalid                 NavFlag = "invalid" | ||||||
|  | 	NavFlagInvalidLeft             NavFlag = "invalid-left" | ||||||
|  | 	NavFlagInvalidRight            NavFlag = "invalid-right" | ||||||
|  | 	NavFlagInvalidSlightLeft       NavFlag = "invalid-slight-left" | ||||||
|  | 	NavFlagInvalidSlightRight      NavFlag = "invalid-slight-right" | ||||||
|  | 	NavFlagInvalidStraight         NavFlag = "invalid-straight" | ||||||
|  | 	NavFlagInvalidUturn            NavFlag = "invalid-uturn" | ||||||
|  | 	NavFlagMergeLeft               NavFlag = "merge-left" | ||||||
|  | 	NavFlagMergeRight              NavFlag = "merge-right" | ||||||
|  | 	NavFlagMergeSlightLeft         NavFlag = "merge-slight-left" | ||||||
|  | 	NavFlagMergeSlightRight        NavFlag = "merge-slight-right" | ||||||
|  | 	NavFlagMergeStraight           NavFlag = "merge-straight" | ||||||
|  | 	NavFlagNewNameLeft             NavFlag = "new-name-left" | ||||||
|  | 	NavFlagNewNameRight            NavFlag = "new-name-right" | ||||||
|  | 	NavFlagNewNameSharpLeft        NavFlag = "new-name-sharp-left" | ||||||
|  | 	NavFlagNewNameSharpRight       NavFlag = "new-name-sharp-right" | ||||||
|  | 	NavFlagNewNameSlightLeft       NavFlag = "new-name-slight-left" | ||||||
|  | 	NavFlagNewNameSlightRight      NavFlag = "new-name-slight-right" | ||||||
|  | 	NavFlagNewNameStraight         NavFlag = "new-name-straight" | ||||||
|  | 	NavFlagNotificationLeft        NavFlag = "notification-left" | ||||||
|  | 	NavFlagNotificationRight       NavFlag = "notification-right" | ||||||
|  | 	NavFlagNotificationSharpLeft   NavFlag = "notification-sharp-left" | ||||||
|  | 	NavFlagNotificationSharpRight  NavFlag = "notification-sharp-right" | ||||||
|  | 	NavFlagNotificationSlightLeft  NavFlag = "notification-slight-left" | ||||||
|  | 	NavFlagNotificationSlightRight NavFlag = "notification-slight-right" | ||||||
|  | 	NavFlagNotificationStraight    NavFlag = "notification-straight" | ||||||
|  | 	NavFlagOffRampLeft             NavFlag = "off-ramp-left" | ||||||
|  | 	NavFlagOffRampRight            NavFlag = "off-ramp-right" | ||||||
|  | 	NavFlagOffRampSharpLeft        NavFlag = "off-ramp-sharp-left" | ||||||
|  | 	NavFlagOffRampSharpRight       NavFlag = "off-ramp-sharp-right" | ||||||
|  | 	NavFlagOffRampSlightLeft       NavFlag = "off-ramp-slight-left" | ||||||
|  | 	NavFlagOffRampSlightRight      NavFlag = "off-ramp-slight-right" | ||||||
|  | 	NavFlagOffRampStraight         NavFlag = "off-ramp-straight" | ||||||
|  | 	NavFlagOnRampLeft              NavFlag = "on-ramp-left" | ||||||
|  | 	NavFlagOnRampRight             NavFlag = "on-ramp-right" | ||||||
|  | 	NavFlagOnRampSharpLeft         NavFlag = "on-ramp-sharp-left" | ||||||
|  | 	NavFlagOnRampSharpRight        NavFlag = "on-ramp-sharp-right" | ||||||
|  | 	NavFlagOnRampSlightLeft        NavFlag = "on-ramp-slight-left" | ||||||
|  | 	NavFlagOnRampSlightRight       NavFlag = "on-ramp-slight-right" | ||||||
|  | 	NavFlagOnRampStraight          NavFlag = "on-ramp-straight" | ||||||
|  | 	NavFlagRotary                  NavFlag = "rotary" | ||||||
|  | 	NavFlagRotaryLeft              NavFlag = "rotary-left" | ||||||
|  | 	NavFlagRotaryRight             NavFlag = "rotary-right" | ||||||
|  | 	NavFlagRotarySharpLeft         NavFlag = "rotary-sharp-left" | ||||||
|  | 	NavFlagRotarySharpRight        NavFlag = "rotary-sharp-right" | ||||||
|  | 	NavFlagRotarySlightLeft        NavFlag = "rotary-slight-left" | ||||||
|  | 	NavFlagRotarySlightRight       NavFlag = "rotary-slight-right" | ||||||
|  | 	NavFlagRotaryStraight          NavFlag = "rotary-straight" | ||||||
|  | 	NavFlagRoundabout              NavFlag = "roundabout" | ||||||
|  | 	NavFlagRoundaboutLeft          NavFlag = "roundabout-left" | ||||||
|  | 	NavFlagRoundaboutRight         NavFlag = "roundabout-right" | ||||||
|  | 	NavFlagRoundaboutSharpLeft     NavFlag = "roundabout-sharp-left" | ||||||
|  | 	NavFlagRoundaboutSharpRight    NavFlag = "roundabout-sharp-right" | ||||||
|  | 	NavFlagRoundaboutSlightLeft    NavFlag = "roundabout-slight-left" | ||||||
|  | 	NavFlagRoundaboutSlightRight   NavFlag = "roundabout-slight-right" | ||||||
|  | 	NavFlagRoundaboutStraight      NavFlag = "roundabout-straight" | ||||||
|  | 	NavFlagTurnLeft                NavFlag = "turn-left" | ||||||
|  | 	NavFlagTurnRight               NavFlag = "turn-right" | ||||||
|  | 	NavFlagTurnSharpLeft           NavFlag = "turn-sharp-left" | ||||||
|  | 	NavFlagTurnSharpRight          NavFlag = "turn-sharp-right" | ||||||
|  | 	NavFlagTurnSlightLeft          NavFlag = "turn-slight-left" | ||||||
|  | 	NavFlagTurnSlightRight         NavFlag = "turn-slight-right" | ||||||
|  | 	NavFlagTurnStright             NavFlag = "turn-stright" | ||||||
|  | 	NavFlagUpdown                  NavFlag = "updown" | ||||||
|  | 	NavFlagUturn                   NavFlag = "uturn" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | type NavigationEvent struct { | ||||||
|  | 	Flag         NavFlag | ||||||
|  | 	Narrative    string | ||||||
|  | 	Dist         string | ||||||
|  | 	Progress     uint8 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | var ( | ||||||
|  | 	ErrNavProgress      = errors.New("progress needs to between 0 and 100") | ||||||
|  | 	ErrNavInvalidFlag   = errors.New("this flag is invalid") | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // Navigation sends a NavigationEvent to the watch | ||||||
|  | func (i *Device) SetNavigation(ev NavigationEvent) error { | ||||||
|  | 	if ev.Progress > 100 { | ||||||
|  | 		return ErrNavProgress | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if ev.Flag != i.navigationEv.Flag { | ||||||
|  | 		log.Debug().Str("func", "Navigation"). | ||||||
|  | 		    Msg("Sending flag") | ||||||
|  | 		if err := i.checkStatus(i.Navigation.flagsChar, NavFlagsChar); err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		if err := i.Navigation.flagsChar.WriteValue([]byte(ev.Flag), nil); err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		i.navigationEv.Flag = ev.Flag | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if ev.Narrative != i.navigationEv.Narrative { | ||||||
|  | 		log.Debug().Str("func", "Navigation"). | ||||||
|  | 		    Msg("Sending narrative") | ||||||
|  | 		if err := i.checkStatus(i.Navigation.narrativeChar, NavNarrativeChar); err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		if err := i.Navigation.narrativeChar.WriteValue([]byte(ev.Narrative), nil); err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		i.navigationEv.Narrative = ev.Narrative | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if ev.Dist != i.navigationEv.Dist { | ||||||
|  | 		log.Debug().Str("func", "Navigation"). | ||||||
|  | 		    Msg("Sending mandist") | ||||||
|  | 		if err := i.checkStatus(i.Navigation.mandistChar, NavManDistChar); err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		if err := i.Navigation.mandistChar.WriteValue([]byte(ev.Dist), nil); err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		i.navigationEv.Dist = ev.Dist | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if ev.Progress != i.navigationEv.Progress { | ||||||
|  | 		log.Debug().Str("func", "Navigation"). | ||||||
|  | 		    Msg("Sending progress") | ||||||
|  | 		if err := i.checkStatus(i.Navigation.progressChar, NavProgressChar); err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		buf := &bytes.Buffer{} | ||||||
|  | 		binary.Write(buf, binary.LittleEndian, ev.Progress) | ||||||
|  | 		if err := i.Navigation.progressChar.WriteValue(buf.Bytes(), nil); err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		i.navigationEv.Progress = ev.Progress | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user