X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Ftext%2Ftext-controller-event-handler.cpp;h=a84747b6d777fbe1208fe55a714244dae255c3ab;hp=c6c40588f5d8f782861d61ad661d114d57efc064;hb=2a7fa48bf8e3808822c354420b2cf273e9a493bd;hpb=ebc31d0e211cb33fe359071bcab608dbdc400080 diff --git a/dali-toolkit/internal/text/text-controller-event-handler.cpp b/dali-toolkit/internal/text/text-controller-event-handler.cpp index c6c4058..a84747b 100644 --- a/dali-toolkit/internal/text/text-controller-event-handler.cpp +++ b/dali-toolkit/internal/text/text-controller-event-handler.cpp @@ -24,6 +24,7 @@ #include // INTERNAL INCLUDES +#include #include #include @@ -80,6 +81,13 @@ void Controller::EventHandler::KeyboardFocusLostEvent(Controller& controller) { if(EventData::INTERRUPTED != controller.mImpl->mEventData->mState) { + // Init selection position + if(controller.mImpl->mEventData->mState == EventData::SELECTING) + { + controller.mImpl->mEventData->mLeftSelectionPosition = controller.mImpl->mEventData->mPrimaryCursorPosition; + controller.mImpl->mEventData->mRightSelectionPosition = controller.mImpl->mEventData->mPrimaryCursorPosition; + } + controller.mImpl->ChangeState(EventData::INACTIVE); if(!controller.mImpl->IsShowingRealText()) @@ -246,12 +254,36 @@ bool Controller::EventHandler::KeyEvent(Controller& controller, const Dali::KeyE DALI_LOG_INFO(gLogFilter, Debug::Verbose, "Controller::KeyEvent %p keyString %s\n", &controller, keyString.c_str()); if(!controller.IsEditable()) return false; - if(!keyString.empty()) + std::string refinedKey = keyString; + if(controller.mImpl->mInputFilter != NULL && !refinedKey.empty()) + { + bool accepted = false; + bool rejected = false; + accepted = controller.mImpl->mInputFilter->Contains(Toolkit::InputFilter::Property::ACCEPTED, keyString); + rejected = controller.mImpl->mInputFilter->Contains(Toolkit::InputFilter::Property::REJECTED, keyString); + + if(!accepted) + { + // The filtered key is set to empty. + refinedKey = ""; + // Signal emits when the character to be inserted is filtered by the accepted filter. + controller.mImpl->mEditableControlInterface->InputFiltered(Toolkit::InputFilter::Property::ACCEPTED); + } + if(rejected) + { + // The filtered key is set to empty. + refinedKey = ""; + // Signal emits when the character to be inserted is filtered by the rejected filter. + controller.mImpl->mEditableControlInterface->InputFiltered(Toolkit::InputFilter::Property::REJECTED); + } + } + + if(!refinedKey.empty()) { // InputMethodContext is no longer handling key-events controller.mImpl->ClearPreEditFlag(); - controller.InsertText(keyString, COMMIT); + controller.InsertText(refinedKey, COMMIT); textChanged = true; @@ -287,12 +319,52 @@ bool Controller::EventHandler::KeyEvent(Controller& controller, const Dali::KeyE (NULL != controller.mImpl->mEditableControlInterface)) { // Do this last since it provides callbacks into application code - controller.mImpl->mEditableControlInterface->TextChanged(); + controller.mImpl->mEditableControlInterface->TextChanged(false); } return true; } +void Controller::EventHandler::AnchorEvent(Controller& controller, float x, float y) +{ + if(!controller.mImpl->mMarkupProcessorEnabled || + !controller.mImpl->mModel->mLogicalModel->mAnchors.Count() || + !controller.mImpl->IsShowingRealText()) + { + return; + } + + CharacterIndex cursorPosition = 0u; + + // Convert from control's coords to text's coords. + const float xPosition = x - controller.mImpl->mModel->mScrollPosition.x; + const float yPosition = y - controller.mImpl->mModel->mScrollPosition.y; + + // Whether to touch point hits on a glyph. + bool matchedCharacter = false; + cursorPosition = Text::GetClosestCursorIndex(controller.mImpl->mModel->mVisualModel, + controller.mImpl->mModel->mLogicalModel, + controller.mImpl->mMetrics, + xPosition, + yPosition, + CharacterHitTest::TAP, + matchedCharacter); + + for(const auto& anchor : controller.mImpl->mModel->mLogicalModel->mAnchors) + { + // Anchor clicked if the calculated cursor position is within the range of anchor. + if(cursorPosition >= anchor.startIndex && cursorPosition < anchor.endIndex) + { + if(controller.mImpl->mAnchorControlInterface && anchor.href) + { + std::string href(anchor.href); + controller.mImpl->mAnchorControlInterface->AnchorClicked(href); + break; + } + } + } +} + void Controller::EventHandler::TapEvent(Controller& controller, unsigned int tapCount, float x, float y) { DALI_ASSERT_DEBUG(controller.mImpl->mEventData && "Unexpected TapEvent"); @@ -742,7 +814,7 @@ InputMethodContext::CallbackData Controller::EventHandler::OnInputMethodContextE (NULL != controller.mImpl->mEditableControlInterface)) { // Do this last since it provides callbacks into application code - controller.mImpl->mEditableControlInterface->TextChanged(); + controller.mImpl->mEditableControlInterface->TextChanged(false); } return callbackData; @@ -852,7 +924,7 @@ void Controller::EventHandler::TextPopupButtonTouched(Controller& controller, Da if(NULL != controller.mImpl->mEditableControlInterface) { - controller.mImpl->mEditableControlInterface->TextChanged(); + controller.mImpl->mEditableControlInterface->TextChanged(true); } break; }