I want to warp images like this:

Added 08-04-2013: I used this code but it's not working properly:
    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 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.ic_launcher);
        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;
    }
In the file manager screen, tap the hamburger icon in the top-left and select Gallery. This will let you pick a photo from your Gallery app. Select the photos you want to combine into one and tap the checkmark in the top-right. Once your photos are in the app, tap Combine Images at the bottom.
STEP 1. Open Your Photo in Photoshop Upload an image that you need to warp and create a duplicate. STEP 2. Select the Layer That You Want to Warp Find the layer that you want to transform in the Layers panel. If you import JPG or PNG photos, this layer might be locked by default. In this case, click on the Lock icon to unlock it.
This is exactly where the Image Warp app comes in. The Image Warp app is essentially Snapseed’s Perspective tool on steroids. It gives you access to a manually adjustable grid that you can use to skew, scale, distort, rotate and completely transform your image.
When you warp a bitmap image (versus a shape or path), the image becomes slightly less sharp each time you commit a transformation; therefore, performing multiple commands before applying the cumulative transformation is preferable to applying each transformation separately.
There are many warp effects available, including standard warp, bulge, pinch, pyramid, and twist. Unlike Ezimba, you need to apply the warp effect manually by clicking on an object or an area of the image and dragging it. You can apply the warp effect anywhere on the image.
There is a much easier way than coding you own. See TransitionDrawable
An extension of LayerDrawables that is intended to cross-fade between the first and second layer. To start the transition, call startTransition(int). To display just the first layer, call resetTransition().
It can be defined in an XML file with the <transition> element. Each Drawable in the transition is defined in a nested <item>
You can find many examples on line, here is one:
<?xml version="1.0" encoding="utf-8"?>
<transition xmlns:android="http://schemas.android.com/apk/res/android">
  <item android:drawable="@drawable/first_image" />
  <item android:drawable="@drawable/second_image" />
</transition>
and the code
final ImageView image = (ImageView) findViewById(R.id.image);
final ToggleButton button = (ToggleButton) findViewById(R.id.button);
button.setOnClickListener(new OnClickListener() {
  @Override
  public void onClick(final View v) {
    TransitionDrawable drawable = (TransitionDrawable) image.getDrawable();
    if (button.isChecked()) {
      drawable.startTransition(500);
    } else {
      drawable.reverseTransition(500);
    }
  }
}); 
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With