diff options
Diffstat (limited to 'native/jni/src/proximity_info_state.cpp')
-rw-r--r-- | native/jni/src/proximity_info_state.cpp | 39 |
1 files changed, 4 insertions, 35 deletions
diff --git a/native/jni/src/proximity_info_state.cpp b/native/jni/src/proximity_info_state.cpp index 8c6a525a7..f78b84e88 100644 --- a/native/jni/src/proximity_info_state.cpp +++ b/native/jni/src/proximity_info_state.cpp @@ -33,8 +33,10 @@ void ProximityInfoState::initInputParams(const int pointerId, const float maxPoi const ProximityInfo *proximityInfo, const int *const inputCodes, const int inputSize, const int *const xCoordinates, const int *const yCoordinates, const int *const times, const int *const pointerIds, const bool isGeometric) { - mIsContinuationPossible = checkAndReturnIsContinuationPossible( - inputSize, xCoordinates, yCoordinates, times, isGeometric); + ASSERT(isGeometric || (inputSize < MAX_WORD_LENGTH)); + mIsContinuationPossible = ProximityInfoStateUtils::checkAndReturnIsContinuationPossible( + inputSize, xCoordinates, yCoordinates, times, mSampledInputSize, &mSampledInputXs, + &mSampledInputYs, &mSampledTimes, &mSampledInputIndice); mProximityInfo = proximityInfo; mHasTouchPositionCorrectionData = proximityInfo->hasTouchPositionCorrectionData(); @@ -149,39 +151,6 @@ void ProximityInfoState::initInputParams(const int pointerId, const float maxPoi } } -bool ProximityInfoState::checkAndReturnIsContinuationPossible(const int inputSize, - const int *const xCoordinates, const int *const yCoordinates, const int *const times, - const bool isGeometric) const { - if (isGeometric) { - for (int i = 0; i < mSampledInputSize; ++i) { - const int index = mSampledInputIndice[i]; - if (index > inputSize || xCoordinates[index] != mSampledInputXs[i] || - yCoordinates[index] != mSampledInputYs[i] || times[index] != mSampledTimes[i]) { - return false; - } - } - } else { - if (inputSize < mSampledInputSize) { - // Assuming the cache is invalid if the previous input size is larger than the new one. - return false; - } - for (int i = 0; i < mSampledInputSize && i < MAX_WORD_LENGTH; ++i) { - if (xCoordinates[i] != mSampledInputXs[i] - || yCoordinates[i] != mSampledInputYs[i]) { - return false; - } - } - } - return true; -} - -int ProximityInfoState::getDuration(const int index) const { - if (index >= 0 && index < mSampledInputSize - 1) { - return mSampledTimes[index + 1] - mSampledTimes[index]; - } - return 0; -} - // TODO: Remove the "scale" parameter // This function basically converts from a length to an edit distance. Accordingly, it's obviously // wrong to compare with mMaxPointToKeyLength. |