Unify handleTouch and handleClick in SampleApp.
Allow each sample to handle clicks in Android SampleApp. Remove SampleWindow::handleTouch. Allow an SkWindow to have multiple clicks. Add an owner pointer to SkView::Click. Reviewed at http://codereview.appspot.com/4643052/ git-svn-id: http://skia.googlecode.com/svn/trunk@1673 2bbb7eff-a529-9590-31e7-b0007b416f81
This commit is contained in:
parent
1eeaf0ba23
commit
d3aed39ab1
@ -210,7 +210,7 @@ JNIEXPORT void JNICALL Java_com_skia_sampleapp_SampleApp_handleClick(JNIEnv* env
|
||||
SkDebugf("motion event ignored\n");
|
||||
return;
|
||||
}
|
||||
gWindow->handleTouch(owner, x, y, state);
|
||||
gWindow->handleClick(x, y, state, (void*) owner);
|
||||
}
|
||||
|
||||
JNIEXPORT void JNICALL Java_com_skia_sampleapp_SampleApp_updateSize(JNIEnv* env,
|
||||
|
@ -142,6 +142,7 @@ public:
|
||||
SkPoint fOrig, fPrev, fCurr;
|
||||
SkIPoint fIOrig, fIPrev, fICurr;
|
||||
State fState;
|
||||
void* fOwner;
|
||||
private:
|
||||
SkEventSinkID fTargetID;
|
||||
char* fType;
|
||||
|
@ -54,7 +54,7 @@ public:
|
||||
// return the bounds of the dirty/inval rgn, or [0,0,0,0] if none
|
||||
const SkIRect& getDirtyBounds() const { return fDirtyRgn.getBounds(); }
|
||||
|
||||
bool handleClick(int x, int y, Click::State);
|
||||
bool handleClick(int x, int y, Click::State, void* owner = NULL);
|
||||
bool handleChar(SkUnichar);
|
||||
bool handleKey(SkKey);
|
||||
bool handleKeyUp(SkKey);
|
||||
@ -74,7 +74,7 @@ public:
|
||||
const char path[]) {}
|
||||
protected:
|
||||
virtual bool onEvent(const SkEvent&);
|
||||
virtual bool onDispatchClick(int x, int y, Click::State);
|
||||
virtual bool onDispatchClick(int x, int y, Click::State, void* owner);
|
||||
// called if part of our bitmap is invalidated
|
||||
virtual void onHandleInval(const SkIRect&);
|
||||
virtual bool onHandleChar(SkUnichar);
|
||||
@ -92,7 +92,8 @@ private:
|
||||
SkBitmap::Config fConfig;
|
||||
SkBitmap fBitmap;
|
||||
SkRegion fDirtyRgn;
|
||||
Click* fClick; // to track clicks
|
||||
|
||||
SkTDArray<Click*> fClicks; // to track clicks
|
||||
|
||||
SkTDArray<SkOSMenu*> fMenus;
|
||||
|
||||
|
@ -1206,7 +1206,8 @@ bool SampleWindow::onHandleKey(SkKey key) {
|
||||
|
||||
static const char gGestureClickType[] = "GestureClickType";
|
||||
|
||||
bool SampleWindow::onDispatchClick(int x, int y, Click::State state) {
|
||||
bool SampleWindow::onDispatchClick(int x, int y, Click::State state,
|
||||
void* owner) {
|
||||
if (Click::kMoved_State == state) {
|
||||
updatePointer(x, y);
|
||||
}
|
||||
@ -1217,7 +1218,7 @@ bool SampleWindow::onDispatchClick(int x, int y, Click::State state) {
|
||||
if (w - x < 16 && h - y < 16) {
|
||||
return false; // let the OS handle the click
|
||||
} else {
|
||||
return this->INHERITED::onDispatchClick(x, y, state);
|
||||
return this->INHERITED::onDispatchClick(x, y, state, owner);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1236,51 +1237,20 @@ SkView::Click* SampleWindow::onFindClickHandler(SkScalar x, SkScalar y) {
|
||||
return new GestureClick(this);
|
||||
}
|
||||
|
||||
union IntPtr {
|
||||
int fInt;
|
||||
void* fPtr;
|
||||
};
|
||||
|
||||
static void* int2ptr(int n) {
|
||||
IntPtr data;
|
||||
data.fInt = n;
|
||||
return data.fPtr;
|
||||
}
|
||||
|
||||
bool SampleWindow::handleTouch(int ownerId, float x, float y, SkView::Click::State state) {
|
||||
void* click = int2ptr(ownerId);
|
||||
switch(state) {
|
||||
case SkView::Click::kDown_State:
|
||||
fGesture.touchBegin(click, x, y);
|
||||
break;
|
||||
case SkView::Click::kMoved_State:
|
||||
fGesture.touchMoved(click, x, y);
|
||||
this->inval(NULL);
|
||||
break;
|
||||
case SkView::Click::kUp_State:
|
||||
fGesture.touchEnd(click);
|
||||
this->inval(NULL);
|
||||
break;
|
||||
default:
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
bool SampleWindow::onClick(Click* click) {
|
||||
if (GestureClick::IsGesture(click)) {
|
||||
float x = SkScalarToFloat(click->fCurr.fX);
|
||||
float y = SkScalarToFloat(click->fCurr.fY);
|
||||
switch (click->fState) {
|
||||
case SkView::Click::kDown_State:
|
||||
fGesture.touchBegin(click, x, y);
|
||||
fGesture.touchBegin(click->fOwner, x, y);
|
||||
break;
|
||||
case SkView::Click::kMoved_State:
|
||||
fGesture.touchMoved(click, x, y);
|
||||
fGesture.touchMoved(click->fOwner, x, y);
|
||||
this->inval(NULL);
|
||||
break;
|
||||
case SkView::Click::kUp_State:
|
||||
fGesture.touchEnd(click);
|
||||
fGesture.touchEnd(click->fOwner);
|
||||
this->inval(NULL);
|
||||
break;
|
||||
}
|
||||
|
@ -77,7 +77,7 @@ protected:
|
||||
virtual bool onEvent(const SkEvent& evt);
|
||||
virtual bool onQuery(SkEvent* evt);
|
||||
|
||||
virtual bool onDispatchClick(int x, int y, Click::State);
|
||||
virtual bool onDispatchClick(int x, int y, Click::State, void* owner);
|
||||
virtual bool onClick(Click* click);
|
||||
virtual Click* onFindClickHandler(SkScalar x, SkScalar y);
|
||||
|
||||
|
@ -300,6 +300,7 @@ SkView::Click::Click(SkView* target)
|
||||
fTargetID = target->getSinkID();
|
||||
fType = NULL;
|
||||
fWeOwnTheType = false;
|
||||
fOwner = NULL;
|
||||
}
|
||||
|
||||
SkView::Click::~Click()
|
||||
|
@ -41,7 +41,7 @@ private:
|
||||
|
||||
SkWindow::SkWindow() : fFocusView(NULL)
|
||||
{
|
||||
fClick = NULL;
|
||||
fClicks.reset();
|
||||
fWaitingOnInval = false;
|
||||
|
||||
#ifdef SK_BUILD_FOR_WINCE
|
||||
@ -55,8 +55,7 @@ SkWindow::SkWindow() : fFocusView(NULL)
|
||||
|
||||
SkWindow::~SkWindow()
|
||||
{
|
||||
delete fClick;
|
||||
|
||||
fClicks.deleteAll();
|
||||
fMenus.deleteAll();
|
||||
}
|
||||
|
||||
@ -369,40 +368,57 @@ bool SkWindow::onHandleKeyUp(SkKey key)
|
||||
return false;
|
||||
}
|
||||
|
||||
bool SkWindow::handleClick(int x, int y, Click::State state) {
|
||||
return this->onDispatchClick(x, y, state);
|
||||
bool SkWindow::handleClick(int x, int y, Click::State state, void *owner) {
|
||||
return this->onDispatchClick(x, y, state, owner);
|
||||
}
|
||||
|
||||
bool SkWindow::onDispatchClick(int x, int y, Click::State state) {
|
||||
bool SkWindow::onDispatchClick(int x, int y, Click::State state,
|
||||
void* owner) {
|
||||
bool handled = false;
|
||||
|
||||
// First, attempt to find an existing click with this owner.
|
||||
int index = -1;
|
||||
for (int i = 0; i < fClicks.count(); i++) {
|
||||
if (owner == fClicks[i]->fOwner) {
|
||||
index = i;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
switch (state) {
|
||||
case Click::kDown_State:
|
||||
if (fClick)
|
||||
delete fClick;
|
||||
fClick = this->findClickHandler(SkIntToScalar(x), SkIntToScalar(y));
|
||||
if (fClick)
|
||||
{
|
||||
SkView::DoClickDown(fClick, x, y);
|
||||
case Click::kDown_State: {
|
||||
if (index != -1) {
|
||||
delete fClicks[index];
|
||||
fClicks.remove(index);
|
||||
}
|
||||
Click* click = this->findClickHandler(SkIntToScalar(x),
|
||||
SkIntToScalar(y));
|
||||
|
||||
if (click) {
|
||||
click->fOwner = owner;
|
||||
*fClicks.append() = click;
|
||||
SkView::DoClickDown(click, x, y);
|
||||
handled = true;
|
||||
}
|
||||
break;
|
||||
}
|
||||
case Click::kMoved_State:
|
||||
if (fClick)
|
||||
{
|
||||
SkView::DoClickMoved(fClick, x, y);
|
||||
if (index != -1) {
|
||||
SkView::DoClickMoved(fClicks[index], x, y);
|
||||
handled = true;
|
||||
}
|
||||
break;
|
||||
case Click::kUp_State:
|
||||
if (fClick)
|
||||
{
|
||||
SkView::DoClickUp(fClick, x, y);
|
||||
delete fClick;
|
||||
fClick = NULL;
|
||||
if (index != -1) {
|
||||
SkView::DoClickUp(fClicks[index], x, y);
|
||||
delete fClicks[index];
|
||||
fClicks.remove(index);
|
||||
handled = true;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
// Do nothing
|
||||
break;
|
||||
}
|
||||
return handled;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user