zoukankan      html  css  js  c++  java
  • chromium截图实现

    声明:本blog是我自己写的,假设要转载,请注明:come from blog of niba!

    chromium终于显示是在ContentView上。但通过硬件加速。渲染合成的网页之前是在surfaceview上的。

    所以。实现chromium的截图能够通过SufraceView的截图去实现。

      自己创建一个SurfaceView的子类,例如以下:

        class ChromiumSurfaceView extends SurfaceView {
            public ChromiumSurfaceView(Context context){
                super(context);
            }
            
            @Override
            public void onDraw(Canvas canvas) {
                // We only need to draw to software canvases, which are used for taking screenshots.
                if (canvas.isHardwareAccelerated()) return;
                Bitmap bitmap = Bitmap.createBitmap(getWidth(), getHeight(),
                        Bitmap.Config.ARGB_8888);
                if (nativeCompositeToBitmap(mNativeContentViewRenderView, bitmap)) {
                    canvas.drawBitmap(bitmap, 0, 0, null);
                }
            }

            public void getBitmap(Canvas canvas){
                this.onDraw(canvas);
            }
        }

       通过方法getBitmap()间接去调用onDraw方法来实现将内容,进行绘制。


        public void getScreenShot() {
            Bitmap bitmap = Bitmap.createBitmap(getWidth(), getHeight(), Bitmap.Config.ARGB_8888);
            Canvas bitCanvas = new Canvas(bitmap);
            ((ChromiumSurfaceView)mSurfaceView).getBitmap(bitCanvas);
           
            try{
                File file = new File("/data/data/com.hisense.goblin/test.jpeg");
                FileOutputStream fos;
                 fos = new FileOutputStream(file);
                  bitmap.compress(Bitmap.CompressFormat.JPEG, 5, fos);
                  fos.close();
            }catch(Exception e){
                e.printStackTrace();
            }
            
       }
     通过这种方法就能够实现截屏了。

     关于SurfaceView的其它信息,能够參考其它的blog,网上讲的非常多。这里不再赘述   

  • 相关阅读:
    (兼容)IE9 以下版本浏览器兼容HTML5的方法
    使用ORACLE 中ROWNUM方法实现数据库分批获取
    更新上传到github的代码
    Spring-AOP
    C++结构体的应用_YCOJ
    基本类型数据封装
    sessionStorage 封装
    Vue国际化四 -- 本地缓存
    Vue国际化三【在下拉框中使用】
    Vue国际化二 【在表格中的使用】
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/5285180.html
Copyright © 2011-2022 走看看