欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android使用API實現(xiàn)圖像扭曲效果示例

 更新時間:2017年08月14日 08:48:20   作者:遲做總比不做強  
這篇文章主要介紹了Android使用API實現(xiàn)圖像扭曲效果,涉及Android坐標運算與圖形繪制相關(guān)操作技巧,需要的朋友可以參考下

本文實例講述了Android使用API實現(xiàn)圖像扭曲效果。分享給大家供大家參考,具體如下:

/**
 * Android API實現(xiàn)圖像扭曲效果
 * @description:
 * @date 2016-7-22 下午2:19:12
 */
public class BitmapMesh extends GraphicsActivity {
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(new SampleView(this));
 }
 private static class SampleView extends View {
   //定義常量,指定該圖片橫向被劃分為20格
  private static final int WIDTH = 20;
   //定義常量,指定該圖片縱向上被劃分為20格
  private static final int HEIGHT = 20;
  //記錄該圖像上包含441個頂點
  private static final int COUNT = (WIDTH + 1) * (HEIGHT + 1);
  //位圖
  private final Bitmap mBitmap;
  //數(shù)組,記錄Bitmap上的21*21個點的坐標
  private final float[] mVerts = new float[COUNT * 2];
   //記錄Bitmap上的21*21個點經(jīng)過扭曲后的坐標
  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.raw.beach);
   //獲取圖像的寬度和高度
   float w = mBitmap.getWidth();
   float h = mBitmap.getHeight();
   //構(gòu)建扭曲數(shù)據(jù)
   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;
      //初始化orig,verts數(shù)組
     //初始化,orig,verts兩個數(shù)組均勻地保存了21 * 21個點的x,y坐標 
     setXY(mVerts, index, fx, fy);
     setXY(mOrig, index, fx, fy);
     index += 1;
    }
   }
   //設(shè)置平移效果
   mMatrix.setTranslate(10, 10);
   //實現(xiàn)亂矩陣逆向坐標映射
   mMatrix.invert(mInverse);
  }
  @Override
  protected void onDraw(Canvas canvas) {
   canvas.drawColor(0xFFCCCCCC);
   //對matrix的變換應(yīng)用到canvas上的所有對象.
   canvas.concat(mMatrix);
   /**
    * bitmap      需要扭曲的源位圖
    * meshWidth   控制在橫向上把該源位圖劃成成多少格
    * meshHeight    控制在縱向上把該源位圖劃成成多少格
    * verts       長度為(meshWidth + 1) * (meshHeight + 1) * 2的數(shù)組,它記錄了扭曲后的位圖各頂點位置
    * vertOffset 控制verts數(shù)組中從第幾個數(shù)組元素開始才對bitmap進行扭曲
    */
   canvas.drawBitmapMesh(mBitmap, WIDTH, HEIGHT, mVerts, 0, null, 0,
     null);
  }
  //根據(jù)觸摸事件的位置計算verts數(shù)組里各元素的值
  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;
     //計算每個坐標點與當前點(cx,cy)之間的距離
    float d = FloatMath.sqrt(dd);
     //扭曲度,距離當前點(cx,cy)越遠,扭曲度越小
    float pull = K / (dd + 0.000001f);
    pull /= (d + 0.000001f);
    //對dst數(shù)組(保存bitmap 上21 * 21個點經(jīng)過扭曲后的坐標)賦值
    if (pull >= 1) {
     dst[i + 0] = cx;
     dst[i + 1] = cy;
    } else {
      //控制各頂點向觸摸事件發(fā)生點偏移
     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;
  @SuppressLint("ClickableViewAccessibility") @Override
  public boolean onTouchEvent(MotionEvent event) {
   float[] pt = { event.getX(), event.getY() };
   //用當前矩陣改變pts中的值,然后存儲在pts中,同上,pts也是存儲點的坐標的數(shù)組
   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;
  }
 }
}

另:關(guān)于Android Matrix可參考:http://www.dbjr.com.cn/article/121048.htm

更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android圖形與圖像處理技巧總結(jié)》、《Android開發(fā)入門與進階教程》、《Android調(diào)試技巧與常見問題解決方法匯總》、《Android基本組件用法總結(jié)》、《Android視圖View技巧總結(jié)》、《Android布局layout技巧總結(jié)》及《Android控件用法總結(jié)

希望本文所述對大家Android程序設(shè)計有所幫助。

相關(guān)文章

  • Android省市區(qū)三級聯(lián)動控件使用方法實例講解

    Android省市區(qū)三級聯(lián)動控件使用方法實例講解

    最近有需求需要實現(xiàn)省市區(qū)三級聯(lián)動,但是發(fā)現(xiàn)之前的實現(xiàn)不夠靈活,自己做了一些優(yōu)化。下面通過實例代碼給大家介紹下Android省市區(qū)三級聯(lián)動控件使用方法
    2017-01-01
  • Android編程實現(xiàn)調(diào)用相冊、相機及拍照后直接裁剪的方法

    Android編程實現(xiàn)調(diào)用相冊、相機及拍照后直接裁剪的方法

    這篇文章主要介紹了Android編程實現(xiàn)調(diào)用相冊、相機及拍照后直接裁剪的方法,涉及Android拍照及圖形處理相關(guān)操作技巧,需要的朋友可以參考下
    2017-02-02
  • Android圖片壓縮的實例詳解

    Android圖片壓縮的實例詳解

    這篇文章主要介紹了Android圖片壓縮的實例詳解的相關(guān)資料,android圖片壓縮主要有兩種方式:壓縮圖片分辨率與壓縮圖片質(zhì)量,需要的朋友可以參考下
    2017-08-08
  • so加載Linker跟NameSpace機制詳解

    so加載Linker跟NameSpace機制詳解

    這篇文章主要為大家介紹了so加載Linker跟NameSpace機制詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • Android中SharedPreference使用實例講解

    Android中SharedPreference使用實例講解

    這篇文章主要介紹了Android中SharedPreference使用方法,實現(xiàn)登陸界面記住密碼功能,感興趣的小伙伴們可以參考一下
    2016-01-01
  • Android AlertDialog的幾種用法詳解

    Android AlertDialog的幾種用法詳解

    這篇文章主要介紹了Android AlertDialog的幾種用法詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Android APP與媒體存儲服務(wù)的交互

    Android APP與媒體存儲服務(wù)的交互

    本文介紹如何在 Android 中,開發(fā)者的 APP 如何使用媒體存儲服務(wù)(包含MediaScanner、MediaProvider以及媒體信息解析等部分),包括如何把 APP 新增或修改的文件更新到媒體數(shù)據(jù)庫、如何在多媒體應(yīng)用中隱藏 APP 產(chǎn)生的文件、如何監(jiān)聽媒體數(shù)據(jù)庫的變化等等。
    2013-10-10
  • android實現(xiàn)快遞跟蹤進度條

    android實現(xiàn)快遞跟蹤進度條

    這篇文章主要為大家詳細介紹了android實現(xiàn)快遞跟蹤進度條,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • 加載頁面遮擋耗時操作任務(wù)頁面--第三方開源之AndroidProgressLayout

    加載頁面遮擋耗時操作任務(wù)頁面--第三方開源之AndroidProgressLayout

    AndroidProgressLayout實現(xiàn)為界面添加圓形進度條。調(diào)用setprogress()方法顯示和隱藏進度條,這篇文章主要介紹了加載頁面遮擋耗時操作任務(wù)頁面--第三方開源之AndroidProgressLayout的相關(guān)資料,需要的朋友可以參考下
    2015-11-11
  • Kotlin如何使用類似C#的yield功能詳解

    Kotlin如何使用類似C#的yield功能詳解

    在語句中使用 yield 關(guān)鍵字,則指示在的方案、運算符或 get 訪問器是迭代器。下面這篇文章主要給大家介紹了關(guān)于Kotlin如何使用類似C#的yield功能的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧
    2018-06-06

最新評論