Merge change 20567

* changes:
  Start rewriting the motion event tracking.
This commit is contained in:
Android (Google) Code Review 2009-08-08 22:33:29 -07:00
commit 0bed662a2e
3 changed files with 95 additions and 220 deletions

View File

@ -20,16 +20,9 @@
#define PARAM_BUBBLE_BITMAP_WIDTH 2
#define PARAM_BUBBLE_BITMAP_HEIGHT 3
//#define STATE_POS_X 0
#define STATE_DONE 1
//#define STATE_PRESSURE 2
#define STATE_ZOOM 3
//#define STATE_WARP 4
#define STATE_ORIENTATION 5
#define STATE_SELECTION 6
#define STATE_FIRST_VISIBLE 7
#define STATE_COUNT 8
#define STATE_TOUCH 9
// State ======
#define STATE_ICON_COUNT 0
#define STATE_SCROLL_X 1
// Scratch variables ======
#define SCRATCH_FADE 0
@ -74,7 +67,7 @@ main(void* con, int ft, int launchID)
pfClearColor(0.0f, 0.0f, 0.0f, 0.0f);
// icons & labels
int iconCount = loadI32(ALLOC_STATE, STATE_COUNT);
int iconCount = loadI32(ALLOC_STATE, STATE_ICON_COUNT);
int pageCount = count_pages(iconCount);
float densityScale = 2.0f / SCREEN_WIDTH;
@ -94,17 +87,17 @@ main(void* con, int ft, int launchID)
float iconWidth = ICON_WIDTH_PX * densityScale;
float columnGutter = COLUMN_GUTTER_PX * densityScale;
float pageLeft = -1;
int icon = 0;
int page;
float labelWidth = loadI32(ALLOC_PARAMS, PARAM_BUBBLE_WIDTH) * densityScale;
float labelTextureWidth = loadI32(ALLOC_PARAMS, PARAM_BUBBLE_BITMAP_WIDTH) * densityScale;
float labelTextureHeight = loadI32(ALLOC_PARAMS, PARAM_BUBBLE_BITMAP_HEIGHT) * densityScale;
int scrollXPx = 100;
pageLeft -= scrollXPx * densityScale;
float pageLeft = -1;
int icon = 0;
int page;
int scrollXPx = loadI32(ALLOC_STATE, STATE_SCROLL_X);
debugI32("scrollXPx", scrollXPx);
pageLeft += scrollXPx * densityScale;
for (page=0; page<pageCount; page++) {
// Bug makes 1.0f alpha fail.
@ -148,7 +141,7 @@ main(void* con, int ft, int launchID)
pageLeft += 2.0f;
}
return 0;
return 1;
}

View File

@ -55,6 +55,11 @@ import android.graphics.PixelFormat;
public class AllAppsView extends RSSurfaceView {
private RenderScript mRS;
private RolloRS mRollo;
private int mLastMotionX;
public AllAppsView(Context context) {
super(context);
setFocusable(true);
@ -69,152 +74,45 @@ public class AllAppsView extends RSSurfaceView {
this(context);
}
private RenderScript mRS;
private RolloRS mRender;
@Override
public void surfaceChanged(SurfaceHolder holder, int format, int w, int h) {
super.surfaceChanged(holder, format, w, h);
mRS = createRenderScript();
mRender = new RolloRS();
mRender.init(mRS, getResources(), w, h);
mRollo = new RolloRS();
mRollo.init(getResources(), w, h);
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event)
{
// break point at here
// this method doesn't work when 'extends View' include 'extends ScrollView'.
return super.onKeyDown(keyCode, event);
}
boolean mControlMode = false;
boolean mZoomMode = false;
boolean mFlingMode = false;
float mFlingX = 0;
float mFlingY = 0;
float mColumn = -1;
float mOldColumn;
float mZoom = 1;
int mIconCount = 29;
int mRows = 4;
int mColumns = (mIconCount + mRows - 1) / mRows;
float mMaxZoom = ((float)mColumns) / 3.f;
void setColumn(boolean clamp)
{
//Log.e("rs", " col = " + Float.toString(mColumn));
float c = mColumn;
if(c > (mColumns -2)) {
c = (mColumns -2);
}
if(c < 0) {
c = 0;
}
mRender.setPosition(c);
if(clamp) {
mColumn = c;
}
}
void computeSelection(float x, float y)
{
float col = mColumn + (x - 0.5f) * 4 + 1.25f;
int iCol = (int)(col + 0.25f);
float row = (y / 0.8f) * mRows;
int iRow = (int)(row - 0.5f);
mRender.setSelected(iCol * mRows + iRow);
}
@Override
public boolean onTouchEvent(MotionEvent ev)
{
boolean ret = true;
int act = ev.getAction();
if (act == ev.ACTION_UP) {
ret = false;
int x = (int)ev.getX();
int deltaX;
switch (ev.getAction()) {
case MotionEvent.ACTION_DOWN:
mLastMotionX = x;
break;
case MotionEvent.ACTION_MOVE:
case MotionEvent.ACTION_OUTSIDE:
deltaX = x - mLastMotionX;
mRollo.mState.scrollX += deltaX;
Log.d(Launcher.LOG_TAG, "updated scrollX=" + mRollo.mState.scrollX);
mRollo.mState.save();
mLastMotionX = x;
break;
case MotionEvent.ACTION_UP:
case MotionEvent.ACTION_CANCEL:
mLastMotionX = -10000;
break;
}
float nx = ev.getX() / getWidth();
float ny = ev.getY() / getHeight();
//Log.e("rs", "width=" + Float.toString(getWidth()));
//Log.e("rs", "height=" + Float.toString(getHeight()));
mRender.setTouch(ret);
if((ny > 0.85f) || mControlMode) {
mFlingMode = false;
// Projector control
if((nx > 0.2f) && (nx < 0.8f) || mControlMode) {
if(act != ev.ACTION_UP) {
float zoom = mMaxZoom;
if(mControlMode) {
if(!mZoomMode) {
zoom = 1.f;
}
float dx = nx - mFlingX;
if((ny < 0.9) && mZoomMode) {
zoom = mMaxZoom - ((0.9f - ny) * 10.f);
if(zoom < 1) {
zoom = 1;
mZoomMode = false;
}
mOldColumn = mColumn;
}
mColumn += dx * 4;// * zoom;
if(zoom > 1.01f) {
mColumn += (mZoom - zoom) * (nx - 0.5f) * 4 * zoom;
}
} else {
mOldColumn = mColumn;
mColumn = ((float)mColumns) / 2;
mControlMode = true;
mZoomMode = true;
}
mZoom = zoom;
mFlingX = nx;
mRender.setZoom(zoom);
if(mZoom < 1.01f) {
computeSelection(nx, ny);
}
} else {
mControlMode = false;
mColumn = mOldColumn;
mRender.setZoom(1.f);
mRender.setSelected(-1);
}
} else {
// Do something with corners here....
}
setColumn(true);
} else {
// icon control
if(act != ev.ACTION_UP) {
if(mFlingMode) {
mColumn += (mFlingX - nx) * 4;
setColumn(true);
}
mFlingMode = true;
mFlingX = nx;
mFlingY = ny;
} else {
mFlingMode = false;
mColumn = (float)(java.lang.Math.floor(mColumn * 0.25f + 0.3f) * 4.f) + 1.f;
setColumn(true);
}
}
return ret;
return true;
}
@Override
@ -232,66 +130,17 @@ public class AllAppsView extends RSSurfaceView {
public class RolloRS {
//public static final int STATE_SELECTED_ID = 0;
public static final int STATE_DONE = 1;
//public static final int STATE_PRESSURE = 2;
public static final int STATE_ZOOM = 3;
//public static final int STATE_WARP = 4;
public static final int STATE_ORIENTATION = 5;
public static final int STATE_SELECTION = 6;
public static final int STATE_FIRST_VISIBLE = 7;
public static final int STATE_COUNT = 8;
public static final int STATE_TOUCH = 9;
// Allocations ======
static final int ALLOC_PARAMS = 0;
static final int ALLOC_STATE = 1;
static final int ALLOC_SCRATCH = 2;
static final int ALLOC_ICON_IDS = 3;
static final int ALLOC_LABEL_IDS = 4;
public RolloRS() {
}
public void init(RenderScript rs, Resources res, int width, int height) {
mRS = rs;
mRes = res;
mWidth = width;
mHeight = height;
initNamed();
initIcons(29);
initRS();
}
public void setPosition(float column) {
mAllocStateBuf[STATE_FIRST_VISIBLE] = (int)(column * (-20));
mAllocState.data(mAllocStateBuf);
}
public void setTouch(boolean touch) {
mAllocStateBuf[STATE_TOUCH] = touch ? 1 : 0;
mAllocState.data(mAllocStateBuf);
}
public void setZoom(float z) {
//Log.e("rs", "zoom " + Float.toString(z));
mAllocStateBuf[STATE_ZOOM] = (int)(z * 1000.f);
mAllocState.data(mAllocStateBuf);
}
public void setSelected(int index) {
//Log.e("rs", "setSelected " + Integer.toString(index));
mAllocStateBuf[STATE_SELECTION] = index;
mAllocStateBuf[STATE_DONE] = 1;
mAllocState.data(mAllocStateBuf);
}
private int mWidth;
private int mHeight;
private Resources mRes;
private RenderScript mRS;
private Script mScript;
private Sampler mSampler;
private Sampler mSamplerText;
@ -305,9 +154,6 @@ public class AllAppsView extends RSSurfaceView {
private ProgramVertex mPVOrtho;
private ProgramVertex.MatrixAllocation mPVOrthoAlloc;
private int[] mAllocStateBuf;
private Allocation mAllocState;
private Allocation[] mIcons;
private int[] mAllocIconIDBuf;
private Allocation mAllocIconID;
@ -320,6 +166,7 @@ public class AllAppsView extends RSSurfaceView {
private Allocation mAllocScratch;
Params mParams;
State mState;
class Params extends IntAllocation {
Params(RenderScript rs) {
@ -331,7 +178,27 @@ public class AllAppsView extends RSSurfaceView {
@AllocationIndex(3) public int bubbleBitmapHeight;
}
private void initNamed() {
class State extends IntAllocation {
State(RenderScript rs) {
super(rs);
}
@AllocationIndex(0) public int iconCount;
@AllocationIndex(1) public int scrollX;
}
public RolloRS() {
}
public void init(Resources res, int width, int height) {
mRes = res;
mWidth = width;
mHeight = height;
initGl();
initData();
initRs();
}
private void initGl() {
Sampler.Builder sb = new Sampler.Builder(mRS);
sb.setMin(Sampler.Value.LINEAR);//_MIP_LINEAR);
sb.setMag(Sampler.Value.LINEAR);
@ -401,8 +268,10 @@ public class AllAppsView extends RSSurfaceView {
Log.e("rs", "Done loading named");
}
private void initIcons(int count) {
private void initData() {
final int count = 29;
mParams = new Params(mRS);
mState = new State(mRS);
mIcons = new Allocation[count];
mAllocIconIDBuf = new int[count];
@ -422,7 +291,6 @@ public class AllAppsView extends RSSurfaceView {
mParams.bubbleHeight = bubble.getMaxBubbleHeight();
mParams.bubbleBitmapWidth = bubble.getBitmapWidth();
mParams.bubbleBitmapHeight = bubble.getBitmapHeight();
mParams.save();
for (int i=0; i<count; i++) {
mIcons[i] = Allocation.createFromBitmapResource(
@ -430,16 +298,19 @@ public class AllAppsView extends RSSurfaceView {
mLabels[i] = makeTextBitmap(bubble, i%9==0 ? "Google Maps" : "Maps");
}
for(int ct=0; ct < count; ct++) {
mIcons[ct].uploadToTexture(0);
mLabels[ct].uploadToTexture(0);
mAllocIconIDBuf[ct] = mIcons[ct].getID();
mAllocLabelIDBuf[ct] = mLabels[ct].getID();
for (int i=0; i<count; i++) {
mIcons[i].uploadToTexture(0);
mLabels[i].uploadToTexture(0);
mAllocIconIDBuf[i] = mIcons[i].getID();
mAllocLabelIDBuf[i] = mLabels[i].getID();
}
mAllocIconID.data(mAllocIconIDBuf);
mAllocLabelID.data(mAllocLabelIDBuf);
Log.e("rs", "Done loading icons");
mState.iconCount = count;
mParams.save();
mState.save();
}
Allocation makeTextBitmap(Utilities.BubbleText bubble, String label) {
@ -449,27 +320,18 @@ public class AllAppsView extends RSSurfaceView {
return a;
}
private void initRS() {
private void initRs() {
ScriptC.Builder sb = new ScriptC.Builder(mRS);
sb.setScript(mRes, R.raw.rollo);
//sb.setScript(mRes, R.raw.rollo2);
sb.setRoot(true);
mScript = sb.create();
mScript.setClearColor(0.0f, 0.0f, 0.0f, 0.0f);
mAllocStateBuf = new int[] {0, 0, 0, 8, 0, 0, -1, 0, mAllocIconIDBuf.length, 0, 0};
mAllocState = Allocation.createSized(mRS,
Element.USER_I32, mAllocStateBuf.length);
mScript.bindAllocation(mParams.getAllocation(), ALLOC_PARAMS);
mScript.bindAllocation(mAllocState, ALLOC_STATE);
mScript.bindAllocation(mState.getAllocation(), ALLOC_STATE);
mScript.bindAllocation(mAllocIconID, ALLOC_ICON_IDS);
mScript.bindAllocation(mAllocScratch, ALLOC_SCRATCH);
mScript.bindAllocation(mAllocLabelID, ALLOC_LABEL_IDS);
setPosition(0);
setZoom(1);
//RenderScript.File f = mRS.fileOpen("/sdcard/test.a3d");
mRS.contextBindRootScript(mScript);
}

View File

@ -19,6 +19,7 @@ package com.android.launcher2;
import android.renderscript.Allocation;
import android.renderscript.Element;
import android.renderscript.RenderScript;
import android.util.Log;
import java.lang.reflect.Field;
@ -45,6 +46,25 @@ public class IntAllocation {
}
}
mBuffer = new int[maxIndex+1];
if (true) {
// helpful debugging check
for (Field f: fields) {
AllocationIndex index = f.getAnnotation(AllocationIndex.class);
if (index != null) {
int i = index.value();
if (mBuffer[i] != 0) {
throw new RuntimeException("@AllocationIndex on field in class "
+ this.getClass().getName() + " with duplicate value "
+ i + " for field " + f.getName() + ". The other field is "
+ fields[mBuffer[i]-1].getName() + '.');
}
mBuffer[i] = i+1;
}
}
for (int i=0; i<mBuffer.length; i++) {
mBuffer[i] = 0;
}
}
mAlloc = Allocation.createSized(mRS, Element.USER_I32, mBuffer.length);
}
int[] buf = mBuffer;