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

解析Android截取手機(jī)屏幕兩種實(shí)現(xiàn)方案

 更新時(shí)間:2017年04月22日 09:41:22   作者:痕跡丶  
這篇文章主要介紹了解析Android截取手機(jī)屏幕兩種實(shí)現(xiàn)方案,非常具有實(shí)用價(jià)值,需要的朋友可以參考下

最近在開發(fā)的過程中,遇到了一個(gè)需要截取屏幕保存為圖片的需求,具體為截取webview的視圖保存圖片。

方法1:首先想到的思路是利用SDK提供的View.getDrawingCache()方法:

 public void printScreen(View view) {
    String imgPath = "/sdcard/test.png";
    view.setDrawingCacheEnabled(true);
    view.buildDrawingCache();
    Bitmap bitmap = view.getDrawingCache();
    if (bitmap != null) {
      try {
        FileOutputStream out = new FileOutputStream(imgPath);
        bitmap.compress(Bitmap.CompressFormat.PNG, 100,
            out);
      } catch (Exception e) {
        e.printStackTrace();
      }
    }
  }

這個(gè)方法在很多情況下都是沒有問題的,比如說截取imageview,TextView,甚至otherview.getRootView();都沒問題,但在WebView上就會(huì)出現(xiàn)webview的部分截取完缺少頁面里的一些內(nèi)容的情況,比如說用webview打開這個(gè)(https://miqt.github.io/jellyfish/)界面,截取的圖片就會(huì)有問題,具體表現(xiàn)為網(wǎng)頁中游動(dòng)的水母沒有顯示在截取的圖片上。

方法2:使用Android系統(tǒng)提供的服務(wù)Context.MEDIA_PROJECTION_SERVICE,進(jìn)行截圖操作。

github地址:https://github.com/miqt/CapWindow

demo源碼下載地址:CapWindow_jb51.rar

關(guān)鍵部分代碼解析:↓

發(fā)送截圖請(qǐng)求

 final MediaProjectionManager projectionManager = (MediaProjectionManager)
        getSystemService(Context.MEDIA_PROJECTION_SERVICE);
 Intent intent = projectionManager.createScreenCaptureIntent();
 startActivityForResult(intent, REQUEST_CODE);

接收返回的結(jié)果:

  @Override
  protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    handleScreenShotIntent(resultCode, data);
  }
  private void handleScreenShotIntent(int resultCode, Intent data) {

    onScreenshotTaskBegan();
    final MediaProjectionManager projectionManager = (MediaProjectionManager)
        getSystemService(Context.MEDIA_PROJECTION_SERVICE);
    final MediaProjection mProjection = projectionManager.getMediaProjection(resultCode, data);
    Point size = Utils.getScreenSize(this);
    final int mWidth = size.x;
    final int mHeight = size.y;
    final ImageReader mImageReader = ImageReader.newInstance(mWidth, mHeight, PixelFormat
        .RGBA_8888, 2);
    final VirtualDisplay display = mProjection.createVirtualDisplay("screen-mirror", mWidth,
        mHeight, DisplayMetrics.DENSITY_MEDIUM,
        DisplayManager.VIRTUAL_DISPLAY_FLAG_PRESENTATION, mImageReader.getSurface(),
        null, null);

    mImageReader.setOnImageAvailableListener(new ImageReader.OnImageAvailableListener() {
      @Override
      public void onImageAvailable(ImageReader mImageReader) {

        Image image = null;
        try {
          image = mImageReader.acquireLatestImage();
          if (image != null) {
            final Image.Plane[] planes = image.getPlanes();
            if (planes.length > 0) {
              final ByteBuffer buffer = planes[0].getBuffer();
              int pixelStride = planes[0].getPixelStride();
              int rowStride = planes[0].getRowStride();
              int rowPadding = rowStride - pixelStride * mWidth;


              // create bitmap
              Bitmap bmp = Bitmap.createBitmap(mWidth + rowPadding / pixelStride,
                  mHeight, Bitmap.Config.ARGB_8888);
              bmp.copyPixelsFromBuffer(buffer);

              Bitmap croppedBitmap = Bitmap.createBitmap(bmp, 0, 0, mWidth, mHeight);

              saveBitmap(croppedBitmap);//保存圖片

              if (croppedBitmap != null) {
                croppedBitmap.recycle();
              }
              if (bmp != null) {
                bmp.recycle();
              }
            }
          }

        } catch (Exception e) {
          e.printStackTrace();
        } finally {
          if (image != null) {
            image.close();
          }
          if (mImageReader != null) {
            mImageReader.close();
          }
          if (display != null) {
            display.release();
          }

          mImageReader.setOnImageAvailableListener(null, null);
          mProjection.stop();

          onScreenshotTaskOver();
        }

      }
    }, getBackgroundHandler());
  }

這個(gè)方法類似使用手機(jī)的系統(tǒng)截屏(音量下鍵+電源鍵),能夠完美的吧當(dāng)前原模原樣的屏幕截取下來,并且修改保存方法的話甚至可以屏幕錄像,但相比于第一種方法,它的缺點(diǎn)是完全和界面上的view沒有關(guān)系,并且在調(diào)用這個(gè)服務(wù)的時(shí)候,會(huì)彈出一個(gè)權(quán)限確認(rèn)的彈框。另外需要注意,這一方法只能在Android 5.0的系統(tǒng)設(shè)備上適用。

總結(jié):

總而言之,這兩種方法各有利弊,使用的時(shí)候要根據(jù)自己的實(shí)際需求做出選擇。以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論