diff options
author | Joaquim <joaquim.org@gmail.com> | 2021-04-04 03:08:51 +0100 |
---|---|---|
committer | Joaquim <joaquim.org@gmail.com> | 2021-04-04 03:08:51 +0100 |
commit | 1d3742e14f09316a1d795527713eb8f9742f0ffb (patch) | |
tree | 6bc6343538506b68256aa057121e063d22f8ed1a /src/drivers/Cst816s.cpp | |
parent | 58a2d000c4d49d96121894d6dd6bb861d7564bea (diff) |
Big UI and navigation Rewrite
new navigation
add some color to the apps
redesign menus
new settings menu
new quick settings
code clean up
size reduction by converting navigation images to font
and more...
Diffstat (limited to 'src/drivers/Cst816s.cpp')
-rw-r--r-- | src/drivers/Cst816s.cpp | 80 |
1 files changed, 30 insertions, 50 deletions
diff --git a/src/drivers/Cst816s.cpp b/src/drivers/Cst816s.cpp index e703b73b..03da76ce 100644 --- a/src/drivers/Cst816s.cpp +++ b/src/drivers/Cst816s.cpp @@ -32,67 +32,47 @@ void Cst816S::Init() { vTaskDelay(5); twiMaster.Read(twiAddress, 0xa7, &dummy, 1); + /* + [2] EnConLR - Continuous operation can slide around + [1] EnConUD - Slide up and down to enable continuous operation + [0] EnDClick - Enable Double-click action + */ + static constexpr uint8_t motionMask = 0b00000101; + twiMaster.Write(twiAddress, 0xEC, &motionMask, 1); + } Cst816S::TouchInfos Cst816S::GetTouchInfo() { Cst816S::TouchInfos info; - auto ret = twiMaster.Read(twiAddress, 0, touchData, 63); + auto ret = twiMaster.Read(twiAddress, 0, touchData, sizeof(touchData)); if(ret != TwiMaster::ErrorCodes::NoError) return {}; auto nbTouchPoints = touchData[2] & 0x0f; -// uint8_t i = 0; -// NRF_LOG_INFO("#########################") - for(int i = 0; i < 1; i++) { - uint8_t pointId = (touchData[touchIdIndex + (touchStep * i)]) >> 4; - if(nbTouchPoints == 0 && pointId == lastTouchId) return info; - - // We fetch only the first touch point (the controller seems to handle only one anyway...) - info.isTouch = true; - - - auto xHigh = touchData[touchXHighIndex + (touchStep * i)] & 0x0f; - auto xLow = touchData[touchXLowIndex + (touchStep * i)]; - uint16_t x = (xHigh << 8) | xLow; - - auto yHigh = touchData[touchYHighIndex + (touchStep * i)] & 0x0f; - auto yLow = touchData[touchYLowIndex + (touchStep * i)]; - uint16_t y = (yHigh << 8) | yLow; - - auto action = touchData[touchEventIndex + (touchStep * i)] >> 6; /* 0 = Down, 1 = Up, 2 = contact*/ - //auto finger = touchData[touchIdIndex + (touchStep * i)] >> 4; - //auto pressure = touchData[touchXYIndex + (touchStep * i)]; - //auto area = touchData[touchMiscIndex + (touchStep * i)] >> 4; - - info.x = x; - info.y = y; - info.action = action; - info.gesture = static_cast<Gestures>(touchData[gestureIndex]); - -// NRF_LOG_INFO("---------------") -// NRF_LOG_INFO("ID : %d", pointId); -// NRF_LOG_INFO("NB : %d", nbTouchPoints); -// NRF_LOG_INFO("X/Y :%d / %d", info.x, info.y); -// NRF_LOG_INFO("Action : %d", action); -// NRF_LOG_INFO("Finger : %d", finger); -// NRF_LOG_INFO("Pressure : %d", pressure); -// NRF_LOG_INFO("area : %d", area); -// NRF_LOG_INFO("Touch : %s", info.isTouch?"Yes" : "No"); -// switch(info.gesture) {// gesture -// case Gestures::None: NRF_LOG_INFO("Gesture : None"); break; -// case Gestures::SlideDown: NRF_LOG_INFO("Gesture : Slide Down"); break; -// case Gestures::SlideUp: NRF_LOG_INFO("Gesture : Slide Up"); break; -// case Gestures::SlideLeft: NRF_LOG_INFO("Gesture : Slide Left"); break; -// case Gestures::SlideRight: NRF_LOG_INFO("Gesture : Slide Right"); break; -// case Gestures::SingleTap: NRF_LOG_INFO("Gesture : Single click"); break; -// case Gestures::DoubleTap: NRF_LOG_INFO("Gesture : Double click"); break; -// case Gestures::LongPress: NRF_LOG_INFO("Gesture : Long press"); break; -// default : NRF_LOG_INFO("Unknown"); break; -// } - } + uint8_t i = 0; + + uint8_t pointId = (touchData[touchIdIndex + (touchStep * i)]) >> 4; + if(nbTouchPoints == 0 && pointId == lastTouchId) return info; + + + info.isTouch = true; + + auto xHigh = touchData[touchXHighIndex + (touchStep * i)] & 0x0f; + auto xLow = touchData[touchXLowIndex + (touchStep * i)]; + uint16_t x = (xHigh << 8) | xLow; + + auto yHigh = touchData[touchYHighIndex + (touchStep * i)] & 0x0f; + auto yLow = touchData[touchYLowIndex + (touchStep * i)]; + uint16_t y = (yHigh << 8) | yLow; + + auto action = touchData[touchEventIndex + (touchStep * i)] >> 6; /* 0 = Down, 1 = Up, 2 = contact*/ + info.x = x; + info.y = y; + info.action = action; + info.gesture = static_cast<Gestures>(touchData[gestureIndex]); return info; } |