Merge change 20567
* changes: Start rewriting the motion event tracking.
This commit is contained in:
commit
0bed662a2e
|
@ -20,16 +20,9 @@
|
||||||
#define PARAM_BUBBLE_BITMAP_WIDTH 2
|
#define PARAM_BUBBLE_BITMAP_WIDTH 2
|
||||||
#define PARAM_BUBBLE_BITMAP_HEIGHT 3
|
#define PARAM_BUBBLE_BITMAP_HEIGHT 3
|
||||||
|
|
||||||
//#define STATE_POS_X 0
|
// State ======
|
||||||
#define STATE_DONE 1
|
#define STATE_ICON_COUNT 0
|
||||||
//#define STATE_PRESSURE 2
|
#define STATE_SCROLL_X 1
|
||||||
#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
|
|
||||||
|
|
||||||
// Scratch variables ======
|
// Scratch variables ======
|
||||||
#define SCRATCH_FADE 0
|
#define SCRATCH_FADE 0
|
||||||
|
@ -74,7 +67,7 @@ main(void* con, int ft, int launchID)
|
||||||
pfClearColor(0.0f, 0.0f, 0.0f, 0.0f);
|
pfClearColor(0.0f, 0.0f, 0.0f, 0.0f);
|
||||||
|
|
||||||
// icons & labels
|
// icons & labels
|
||||||
int iconCount = loadI32(ALLOC_STATE, STATE_COUNT);
|
int iconCount = loadI32(ALLOC_STATE, STATE_ICON_COUNT);
|
||||||
int pageCount = count_pages(iconCount);
|
int pageCount = count_pages(iconCount);
|
||||||
|
|
||||||
float densityScale = 2.0f / SCREEN_WIDTH;
|
float densityScale = 2.0f / SCREEN_WIDTH;
|
||||||
|
@ -94,17 +87,17 @@ main(void* con, int ft, int launchID)
|
||||||
float iconWidth = ICON_WIDTH_PX * densityScale;
|
float iconWidth = ICON_WIDTH_PX * densityScale;
|
||||||
float columnGutter = COLUMN_GUTTER_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 labelWidth = loadI32(ALLOC_PARAMS, PARAM_BUBBLE_WIDTH) * densityScale;
|
||||||
float labelTextureWidth = loadI32(ALLOC_PARAMS, PARAM_BUBBLE_BITMAP_WIDTH) * densityScale;
|
float labelTextureWidth = loadI32(ALLOC_PARAMS, PARAM_BUBBLE_BITMAP_WIDTH) * densityScale;
|
||||||
float labelTextureHeight = loadI32(ALLOC_PARAMS, PARAM_BUBBLE_BITMAP_HEIGHT) * densityScale;
|
float labelTextureHeight = loadI32(ALLOC_PARAMS, PARAM_BUBBLE_BITMAP_HEIGHT) * densityScale;
|
||||||
|
|
||||||
int scrollXPx = 100;
|
float pageLeft = -1;
|
||||||
pageLeft -= scrollXPx * densityScale;
|
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++) {
|
for (page=0; page<pageCount; page++) {
|
||||||
// Bug makes 1.0f alpha fail.
|
// Bug makes 1.0f alpha fail.
|
||||||
|
@ -148,7 +141,7 @@ main(void* con, int ft, int launchID)
|
||||||
pageLeft += 2.0f;
|
pageLeft += 2.0f;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -55,6 +55,11 @@ import android.graphics.PixelFormat;
|
||||||
|
|
||||||
|
|
||||||
public class AllAppsView extends RSSurfaceView {
|
public class AllAppsView extends RSSurfaceView {
|
||||||
|
private RenderScript mRS;
|
||||||
|
private RolloRS mRollo;
|
||||||
|
|
||||||
|
private int mLastMotionX;
|
||||||
|
|
||||||
public AllAppsView(Context context) {
|
public AllAppsView(Context context) {
|
||||||
super(context);
|
super(context);
|
||||||
setFocusable(true);
|
setFocusable(true);
|
||||||
|
@ -69,152 +74,45 @@ public class AllAppsView extends RSSurfaceView {
|
||||||
this(context);
|
this(context);
|
||||||
}
|
}
|
||||||
|
|
||||||
private RenderScript mRS;
|
@Override
|
||||||
private RolloRS mRender;
|
|
||||||
|
|
||||||
public void surfaceChanged(SurfaceHolder holder, int format, int w, int h) {
|
public void surfaceChanged(SurfaceHolder holder, int format, int w, int h) {
|
||||||
super.surfaceChanged(holder, format, w, h);
|
super.surfaceChanged(holder, format, w, h);
|
||||||
|
|
||||||
mRS = createRenderScript();
|
mRS = createRenderScript();
|
||||||
mRender = new RolloRS();
|
mRollo = new RolloRS();
|
||||||
mRender.init(mRS, getResources(), w, h);
|
mRollo.init(getResources(), w, h);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onKeyDown(int keyCode, KeyEvent event)
|
public boolean onKeyDown(int keyCode, KeyEvent event)
|
||||||
{
|
{
|
||||||
// break point at here
|
|
||||||
// this method doesn't work when 'extends View' include 'extends ScrollView'.
|
// this method doesn't work when 'extends View' include 'extends ScrollView'.
|
||||||
return super.onKeyDown(keyCode, event);
|
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
|
@Override
|
||||||
public boolean onTouchEvent(MotionEvent ev)
|
public boolean onTouchEvent(MotionEvent ev)
|
||||||
{
|
{
|
||||||
boolean ret = true;
|
int x = (int)ev.getX();
|
||||||
int act = ev.getAction();
|
int deltaX;
|
||||||
if (act == ev.ACTION_UP) {
|
switch (ev.getAction()) {
|
||||||
ret = false;
|
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;
|
||||||
}
|
}
|
||||||
|
return true;
|
||||||
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;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -232,66 +130,17 @@ public class AllAppsView extends RSSurfaceView {
|
||||||
|
|
||||||
public class RolloRS {
|
public class RolloRS {
|
||||||
|
|
||||||
//public static final int STATE_SELECTED_ID = 0;
|
// Allocations ======
|
||||||
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;
|
|
||||||
|
|
||||||
static final int ALLOC_PARAMS = 0;
|
static final int ALLOC_PARAMS = 0;
|
||||||
static final int ALLOC_STATE = 1;
|
static final int ALLOC_STATE = 1;
|
||||||
static final int ALLOC_SCRATCH = 2;
|
static final int ALLOC_SCRATCH = 2;
|
||||||
static final int ALLOC_ICON_IDS = 3;
|
static final int ALLOC_ICON_IDS = 3;
|
||||||
static final int ALLOC_LABEL_IDS = 4;
|
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 mWidth;
|
||||||
private int mHeight;
|
private int mHeight;
|
||||||
|
|
||||||
private Resources mRes;
|
private Resources mRes;
|
||||||
private RenderScript mRS;
|
|
||||||
private Script mScript;
|
private Script mScript;
|
||||||
private Sampler mSampler;
|
private Sampler mSampler;
|
||||||
private Sampler mSamplerText;
|
private Sampler mSamplerText;
|
||||||
|
@ -305,9 +154,6 @@ public class AllAppsView extends RSSurfaceView {
|
||||||
private ProgramVertex mPVOrtho;
|
private ProgramVertex mPVOrtho;
|
||||||
private ProgramVertex.MatrixAllocation mPVOrthoAlloc;
|
private ProgramVertex.MatrixAllocation mPVOrthoAlloc;
|
||||||
|
|
||||||
private int[] mAllocStateBuf;
|
|
||||||
private Allocation mAllocState;
|
|
||||||
|
|
||||||
private Allocation[] mIcons;
|
private Allocation[] mIcons;
|
||||||
private int[] mAllocIconIDBuf;
|
private int[] mAllocIconIDBuf;
|
||||||
private Allocation mAllocIconID;
|
private Allocation mAllocIconID;
|
||||||
|
@ -320,6 +166,7 @@ public class AllAppsView extends RSSurfaceView {
|
||||||
private Allocation mAllocScratch;
|
private Allocation mAllocScratch;
|
||||||
|
|
||||||
Params mParams;
|
Params mParams;
|
||||||
|
State mState;
|
||||||
|
|
||||||
class Params extends IntAllocation {
|
class Params extends IntAllocation {
|
||||||
Params(RenderScript rs) {
|
Params(RenderScript rs) {
|
||||||
|
@ -331,7 +178,27 @@ public class AllAppsView extends RSSurfaceView {
|
||||||
@AllocationIndex(3) public int bubbleBitmapHeight;
|
@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);
|
Sampler.Builder sb = new Sampler.Builder(mRS);
|
||||||
sb.setMin(Sampler.Value.LINEAR);//_MIP_LINEAR);
|
sb.setMin(Sampler.Value.LINEAR);//_MIP_LINEAR);
|
||||||
sb.setMag(Sampler.Value.LINEAR);
|
sb.setMag(Sampler.Value.LINEAR);
|
||||||
|
@ -401,8 +268,10 @@ public class AllAppsView extends RSSurfaceView {
|
||||||
Log.e("rs", "Done loading named");
|
Log.e("rs", "Done loading named");
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initIcons(int count) {
|
private void initData() {
|
||||||
|
final int count = 29;
|
||||||
mParams = new Params(mRS);
|
mParams = new Params(mRS);
|
||||||
|
mState = new State(mRS);
|
||||||
|
|
||||||
mIcons = new Allocation[count];
|
mIcons = new Allocation[count];
|
||||||
mAllocIconIDBuf = new int[count];
|
mAllocIconIDBuf = new int[count];
|
||||||
|
@ -422,7 +291,6 @@ public class AllAppsView extends RSSurfaceView {
|
||||||
mParams.bubbleHeight = bubble.getMaxBubbleHeight();
|
mParams.bubbleHeight = bubble.getMaxBubbleHeight();
|
||||||
mParams.bubbleBitmapWidth = bubble.getBitmapWidth();
|
mParams.bubbleBitmapWidth = bubble.getBitmapWidth();
|
||||||
mParams.bubbleBitmapHeight = bubble.getBitmapHeight();
|
mParams.bubbleBitmapHeight = bubble.getBitmapHeight();
|
||||||
mParams.save();
|
|
||||||
|
|
||||||
for (int i=0; i<count; i++) {
|
for (int i=0; i<count; i++) {
|
||||||
mIcons[i] = Allocation.createFromBitmapResource(
|
mIcons[i] = Allocation.createFromBitmapResource(
|
||||||
|
@ -430,16 +298,19 @@ public class AllAppsView extends RSSurfaceView {
|
||||||
mLabels[i] = makeTextBitmap(bubble, i%9==0 ? "Google Maps" : "Maps");
|
mLabels[i] = makeTextBitmap(bubble, i%9==0 ? "Google Maps" : "Maps");
|
||||||
}
|
}
|
||||||
|
|
||||||
for(int ct=0; ct < count; ct++) {
|
for (int i=0; i<count; i++) {
|
||||||
mIcons[ct].uploadToTexture(0);
|
mIcons[i].uploadToTexture(0);
|
||||||
mLabels[ct].uploadToTexture(0);
|
mLabels[i].uploadToTexture(0);
|
||||||
mAllocIconIDBuf[ct] = mIcons[ct].getID();
|
mAllocIconIDBuf[i] = mIcons[i].getID();
|
||||||
mAllocLabelIDBuf[ct] = mLabels[ct].getID();
|
mAllocLabelIDBuf[i] = mLabels[i].getID();
|
||||||
}
|
}
|
||||||
mAllocIconID.data(mAllocIconIDBuf);
|
mAllocIconID.data(mAllocIconIDBuf);
|
||||||
mAllocLabelID.data(mAllocLabelIDBuf);
|
mAllocLabelID.data(mAllocLabelIDBuf);
|
||||||
|
|
||||||
Log.e("rs", "Done loading icons");
|
mState.iconCount = count;
|
||||||
|
|
||||||
|
mParams.save();
|
||||||
|
mState.save();
|
||||||
}
|
}
|
||||||
|
|
||||||
Allocation makeTextBitmap(Utilities.BubbleText bubble, String label) {
|
Allocation makeTextBitmap(Utilities.BubbleText bubble, String label) {
|
||||||
|
@ -449,27 +320,18 @@ public class AllAppsView extends RSSurfaceView {
|
||||||
return a;
|
return a;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initRS() {
|
private void initRs() {
|
||||||
ScriptC.Builder sb = new ScriptC.Builder(mRS);
|
ScriptC.Builder sb = new ScriptC.Builder(mRS);
|
||||||
sb.setScript(mRes, R.raw.rollo);
|
sb.setScript(mRes, R.raw.rollo);
|
||||||
//sb.setScript(mRes, R.raw.rollo2);
|
|
||||||
sb.setRoot(true);
|
sb.setRoot(true);
|
||||||
mScript = sb.create();
|
mScript = sb.create();
|
||||||
mScript.setClearColor(0.0f, 0.0f, 0.0f, 0.0f);
|
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(mParams.getAllocation(), ALLOC_PARAMS);
|
||||||
mScript.bindAllocation(mAllocState, ALLOC_STATE);
|
mScript.bindAllocation(mState.getAllocation(), ALLOC_STATE);
|
||||||
mScript.bindAllocation(mAllocIconID, ALLOC_ICON_IDS);
|
mScript.bindAllocation(mAllocIconID, ALLOC_ICON_IDS);
|
||||||
mScript.bindAllocation(mAllocScratch, ALLOC_SCRATCH);
|
mScript.bindAllocation(mAllocScratch, ALLOC_SCRATCH);
|
||||||
mScript.bindAllocation(mAllocLabelID, ALLOC_LABEL_IDS);
|
mScript.bindAllocation(mAllocLabelID, ALLOC_LABEL_IDS);
|
||||||
setPosition(0);
|
|
||||||
setZoom(1);
|
|
||||||
|
|
||||||
//RenderScript.File f = mRS.fileOpen("/sdcard/test.a3d");
|
|
||||||
|
|
||||||
mRS.contextBindRootScript(mScript);
|
mRS.contextBindRootScript(mScript);
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,6 +19,7 @@ package com.android.launcher2;
|
||||||
import android.renderscript.Allocation;
|
import android.renderscript.Allocation;
|
||||||
import android.renderscript.Element;
|
import android.renderscript.Element;
|
||||||
import android.renderscript.RenderScript;
|
import android.renderscript.RenderScript;
|
||||||
|
import android.util.Log;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
|
@ -45,6 +46,25 @@ public class IntAllocation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
mBuffer = new int[maxIndex+1];
|
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);
|
mAlloc = Allocation.createSized(mRS, Element.USER_I32, mBuffer.length);
|
||||||
}
|
}
|
||||||
int[] buf = mBuffer;
|
int[] buf = mBuffer;
|
||||||
|
|
Loading…
Reference in New Issue