Как изменить образец растрового изображения, чтобы включить эффект «рыбий глаз»? - PullRequest
5 голосов
/ 01 апреля 2011

У меня есть пример кода, который поставляется с Android, который искажает растровое изображение (Bitmapmesh.java). Я хочу, чтобы на моем изображении был круг, который дает эффект «рыбий глаз». Я новичок в Android и особенно в графике, возможно ли создать этот эффект в образце растрового изображения?

Я не уверен, с чего начать, поэтому любые указатели будут оценены. Может ли кто-нибудь дать мне общее представление о том, что с этим связано, например, я хотел бы сначала поставить кружок на изображение. Я поместил кнопки поверх изображений до того, как они, кажется, всплыли, это было сделано с помощью относительной компоновки, а затем добавлением дочерних кнопок. то, что я пытаюсь сделать сейчас, отличается и, вероятно, будет включать в себя вызов некоторого метода onDraw? У меня также есть алгоритм, который делает искажения, я просто не уверен, как применить это к изображению.

Ниже приведен код растрового изображения. Может ли кто-нибудь рассказать мне, с чего начать, даже если сначала он просто поместит кружок на изображение, тогда я смогу реализовать эффект.

спасибо мат

import java.io.BufferedInputStream; import java.io.DataInputStream; импорт java.io.File; import java.io.FileInputStream; import java.io.InputStream;

import android.content.Context; импорт android.graphics. ; импорт android.os.Bundle; импорт android.os.Environment; импорт android.view. ; import android.util.FloatMath;

открытый класс BitMapFishEye расширяет GraphicsActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(new SampleView(this));
}

private static class SampleView extends View {
    private static final int WIDTH = 20;
    private static final int HEIGHT = 20;
    private static final int COUNT = (WIDTH + 1) * (HEIGHT + 1);

    private final Bitmap mBitmap;
    private final float[] mVerts = new float[COUNT*2];
    private final float[] mOrig = new float[COUNT*2];

    private final Matrix mMatrix = new Matrix();
    private final Matrix mInverse = new Matrix();

    private File tempFile;
    private byte[] imageArray;

    private static void setXY(float[] array, int index, float x, float y) {
        array[index*2 + 0] = x;
        array[index*2 + 1] = y;
    }

    public SampleView(Context context) {
        super(context);
        setFocusable(true);

       /* mBitmap = BitmapFactory.decodeResource(getResources(),
                                                 R.drawable.beach);*/
        tempFile = new File(Environment.getExternalStorageDirectory().
                getAbsolutePath() + "/"+"image.jpg");

        imageArray = new byte[(int)tempFile.length()];

     try{

        InputStream is = new FileInputStream(tempFile);
            BufferedInputStream bis = new BufferedInputStream(is);
            DataInputStream dis = new DataInputStream(bis);


            int i = 0;

            while (dis.available() > 0) {
            imageArray[i] = dis.readByte();
            i++;
            }

            dis.close();

     } catch (Exception e) {

               e.printStackTrace();
            }


        BitmapFactory.Options bfo = new BitmapFactory.Options();
        bfo.inSampleSize = 5;
        mBitmap = BitmapFactory.decodeByteArray(imageArray, 0, imageArray.length, bfo);

        float w = mBitmap.getWidth();
        float h = mBitmap.getHeight();
        // construct our mesh
        int index = 0;
        for (int y = 0; y <= HEIGHT; y++) {
            float fy = h * y / HEIGHT;
            for (int x = 0; x <= WIDTH; x++) {
                float fx = w * x / WIDTH;                    
                setXY(mVerts, index, fx, fy);
                setXY(mOrig, index, fx, fy);
                index += 1;
            }
        }

        mMatrix.setTranslate(10, 10);
        mMatrix.invert(mInverse);
    }

    @Override protected void onDraw(Canvas canvas) {
        canvas.drawColor(0xFFCCCCCC);

        canvas.concat(mMatrix);
        canvas.drawBitmapMesh(mBitmap, WIDTH, HEIGHT, mVerts, 0,
                              null, 0, null);
    }

    private void warp(float cx, float cy) {
        final float K = 10000;
        float[] src = mOrig;
        float[] dst = mVerts;
        for (int i = 0; i < COUNT*2; i += 2) {
            float x = src[i+0];
            float y = src[i+1];
            float dx = cx - x;
            float dy = cy - y;
            float dd = dx*dx + dy*dy;
            float d = FloatMath.sqrt(dd);
            float pull = K / (dd + 0.000001f);

            pull /= (d + 0.000001f);
         //   android.util.Log.d("skia", "index " + i + " dist=" + d + " pull=" + pull);

            if (pull >= 1) {
                dst[i+0] = cx;
                dst[i+1] = cy;
            } else {
                dst[i+0] = x + dx * pull;
                dst[i+1] = y + dy * pull;
            }
        }
    }

    private int mLastWarpX = -9999; // don't match a touch coordinate
    private int mLastWarpY;

    @Override public boolean onTouchEvent(MotionEvent event) {
        float[] pt = { event.getX(), event.getY() };
        mInverse.mapPoints(pt);

        int x = (int)pt[0];
        int y = (int)pt[1];
        if (mLastWarpX != x || mLastWarpY != y) {
            mLastWarpX = x;
            mLastWarpY = y;
            warp(pt[0], pt[1]);
            invalidate();
        }
        return true;
    }
}

}

...