ControllerManager Programmer Notes - psmoveservice/PSMoveService GitHub Wiki

Controller Manager

ControllerManager
    Members
        std::deque<eCommonTrackingColorID> m_available_controller_color_ids;
        std::string m_bluetooth_host_address;
        
    Functions
        /// Call hid_init()
        bool startup() override;
       
        void updateStateAndPredict(TrackerManager* tracker_manager);
        void publish() override;
        void setControllerRumble(int controller_id, float rumble_amount, CommonControllerState::RumbleChannel channel);

        eCommonTrackingColorID allocateTrackingColorID();
        void claimTrackingColorID(const ServerControllerView *controller_view, eCommonTrackingColorID color_id);
        void freeTrackingColorID(eCommonTrackingColorID color_id);

ServerControllerView
    Functions
        bool open(const class DeviceEnumerator *enumerator) override;
        void close() override;
        // Tell the pose filter that the controller is aligned with global forward 
        // with the given pose relative to it's identity pose.
        // Recenter the pose filter state accordingly.
        bool recenterOrientation(const CommonDeviceQuaternion& q_pose_relative_to_identity_pose);
        // Recreate and initialize the pose filter for the controller
        void resetPoseFilter();
        // Compute pose/prediction of tracking blob+IMU state
        void updateOpticalPoseEstimation(TrackerManager* tracker_manager);
        void updateStateAndPredict();
        // Registers the address of the bluetooth adapter on the host PC with the controller
        bool setHostBluetoothAddress(const std::string &address);        
        IDeviceInterface* getDevice() const override {return m_device;}
        inline class IPoseFilter * getPoseFilterMutable() { return m_pose_filter; }
        inline const class IPoseFilter * getPoseFilter() const { return m_pose_filter; }
        // Estimate the given pose if the controller at some point into the future
        CommonDevicePose getFilteredPose(float time= 0.f) const;
        // Get the current physics from the filter position and orientation
        CommonDevicePhysics getFilteredPhysics() const;
        // Returns true if the device is connected via Bluetooth, false if by USB
        bool getIsBluetooth() const;
        // Returns true if the device can stream controller data over it's current connection type (Bluetooth/USB)
        bool getIsStreamable() const;
        // Returns the full usb device path for the controller
        std::string getUSBDevicePath() const;
        // Returns the vendor ID of the controller
        int getVendorID() const;
        // Returns the product ID of the controller
        int getProductID() const;
        // Returns the serial number for the controller
        std::string getSerial() const;
        // Gets the host bluetooth address registered with the 
        std::string getAssignedHostBluetoothAddress() const;
        // Returns what type of controller this controller view represents
        CommonDeviceState::eDeviceType getControllerDeviceType() const;
        // Fetch the controller state at the given sample index.
        // A lookBack of 0 corresponds to the most recent data.
        const CommonControllerState * getState(int lookBack = 0) const;
        // Returns true if the system button was pressed this frame on this controller
        bool getWasSystemButtonPressed() const;
        // Sets the bulb LED color to some new override color
        // If tracking was active this likely will affect controller tracking
        void setLEDOverride(unsigned char r, unsigned char g, unsigned char b);
        // Removes the over led color and restores the tracking color
        // of the controller is currently being tracked
        void clearLEDOverride();
        // Returns true 
        inline bool getIsLEDOverrideActive() const { return m_LED_override_active; }
        // Get the currently assigned tracking color ID for the controller
        eCommonTrackingColorID getTrackingColorID() const;
        // Set the assigned tracking color ID for the controller
        void setTrackingColorID(eCommonTrackingColorID colorID);
        // Get the tracking is enabled on this controller
        inline bool getIsTrackingEnabled() const { return m_tracking_enabled && m_multicam_pose_estimation != nullptr; }
        // Increment the position tracking listener count
        // Starts position tracking this controller if the count was zero
        void startTracking();
        // Decrements the position tracking listener count
        // Stop tracking this controller if this count becomes zero
        void stopTracking();
        // Get the tracking shape for the controller
        bool getTrackingShape(CommonDeviceTrackingShape &outTrackingShape) const;
        // Get the prediction time used for ROI tracking
        float getROIPredictionTime() const;
        // Get the pose estimate relative to the given tracker id
        inline const ControllerOpticalPoseEstimation *getTrackerPoseEstimate(int trackerId) const {
        // Get the pose estimate derived from multicam pose tracking
        inline const ControllerOpticalPoseEstimation *getMulticamPoseEstimate() const { 
        // return true if one or more cameras saw this controller last update
        inline bool getIsCurrentlyTracking() const
        // Set the rumble value between 0.f-1.f on a channel
        bool setControllerRumble(float rumble_amount, CommonControllerState::RumbleChannel channel);
        
    Members
        // Tracking color state
        std::tuple<unsigned char, unsigned char, unsigned char> m_tracking_color;
        int m_tracking_listener_count;
        bool m_tracking_enabled;
        
        // Region-of-Interest state
        int m_roi_disable_count;
        
        // Override color state
        std::tuple<unsigned char, unsigned char, unsigned char> m_LED_override_color;
        bool m_LED_override_active;

        // Device state
        IControllerInterface *m_device;
        
        // Filter state
        ControllerOpticalPoseEstimation *m_tracker_pose_estimations; // array of size TrackerManager::k_max_devices
        ControllerOpticalPoseEstimation *m_multicam_pose_estimation;
        class IPoseFilter *m_pose_filter;
        class PoseFilterSpace *m_pose_filter_space;
        int m_lastPollSeqNumProcessed;
        std::chrono::time_point<std::chrono::high_resolution_clock> m_last_filter_update_timestamp;
        bool m_last_filter_update_timestamp_valid;

IControllerInterface

PSNaviController
PSMoveController
PSDualShock4Controller

Pose Filter Programmer Notes