Move OBD2 reading/parsing logic from Vehicle page to dedicated plugin #93
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description:
Problem with current vehicle page is that it depends on OBDII protocol and it is not supported on 100% cars.
Even worse, on unsupported vehicles, in order to query OBD2 status, it generates CANbus messages to unsupported canbus frames.
I moved away all canbus/obd2 code to separate vehicle plugin obd2 (
plugins/vehicle/obd2
). This way if car supports it, user can enable it under plugins.If not, user can choose from other plugin which can read CANbus messages and provide data to Vehicle page.
Each vehicle plugin can update Vehicle page using new arbiter method
void vehicle_update_data(QString gauge_id, int value);
As a bonus I enabled Fuel Consumption gauge, which was disabled in original Vehicle page.
Checklist: