如何从 ionic/cordova/phonegap 中的布局截取屏幕截图?

Posted

技术标签:

【中文标题】如何从 ionic/cordova/phonegap 中的布局截取屏幕截图?【英文标题】:How to take screen shot from a layout in ionic/cordova/phonegap? 【发布时间】:2015-10-10 12:57:42 【问题描述】:

我正在尝试使用 ionic 构建基于 cordova 的应用程序。 在我的应用程序中,有一个部分,用户可以从我们的服务器中选择图像并移动它们或对其执行一些操作(如缩放和旋转......)。最后,我希望他们能够在我们的网站和社交媒体上分享结果。我的问题是如何从他们构建的布局中截取屏幕截图?我已经看过 html2canvas 库,但是它有一个问题,即保存在我们服务器上的源图像没有截屏。

【问题讨论】:

以下所有解决方案均未将图像保存在 ios 的图库中。你能帮忙吗? 【参考方案1】:

将以下插件安装到您的项目中

cordova plugin add https://github.com/gitawego/cordova-screenshot.git

将此服务添加到您的 Angular 模块中

.service('$cordovaScreenshot', ['$q', function($q) 
    return 
        capture: function(filename, extension, quality) 
            extension = extension || 'jpg';
            quality = quality || '100';

            var defer = $q.defer();

            navigator.screenshot.save(function(error, res) 
                if (error) 
                    console.error(error);
                    defer.reject(error);
                 else 
                    console.log('screenshot saved in: ', res.filePath);
                    defer.resolve(res.filePath);
                
            , extension, quality, filename);

            return defer.promise;
        
    ;
]);

然后,您只需添加一个按钮即可使用此服务进行屏幕截图。

我有一个很好的例子来截取屏幕截图并在 Facebook 上分享:

//Take a picture
$cordovaScreenshot.capture()
     .then(function(result) 
          //on success you get the image url

          //post on facebook (image & link can be null)
          $cordovaSocialSharing
            .shareViaFacebook("Text to post here...", result, "Link to share")
                  .then(function(result) 
                        //do something on post success or ignore it...
                   , function(err) 
                        console.log("there was an error sharing!");
                   );
     , function(err) 
         console.log("there was an error taking a a screenshot!");
 );

请注意,此示例使用 ngCordova 的社交分享插件: http://ngcordova.com/docs/plugins/socialSharing/

【讨论】:

【参考方案2】:

将 Screenshot.js 文件归档到:

var formats = ['png','jpg'];

function Screenshot() 


Screenshot.prototype.save = function (callback,format,quality, filename) 
    format = (format || 'png').toLowerCase();
    filename = filename || 'screenshot_'+Math.round((+(new Date()) + Math.random()));
    if(formats.indexOf(format) === -1)
        return callback && callback(new Error('invalid format '+format));
    
    quality = typeof(quality) !== 'number'?100:quality;
    cordova.exec(function(res)
        callback && callback(null,res);
    , function(error)
        callback && callback(error);
    , "Screenshot", "saveScreenshot", [format, quality, filename]);
;

Screenshot.install = function () 
      if (!window.plugins) 
        window.plugins = ;
      

      window.plugins.screenshot = new Screenshot();
      return window.plugins.screenshot;
    ;

cordova.addConstructor(Screenshot.install); 

This way I can make the call with the following code:

window.plugins.screenshot.save(function(error,res)
          if(error)
            alert(error);
          else
            alert('ok',res.filePath); //should be path/to/myScreenshot.jpg
          
        ,'jpg',50,'myScreenShot');

这在我的 android 智能手机上运行良好。

我也在res/xml/config.xml文件中添加了:

<feature name="Screenshot">
    <param name="android-package" value="org.apache.cordova.screenshot.Screenshot"/>
</feature>

在 AndroidManifest.xml 文件中:

并在以下包中添加了java类:org.apache.cordova.screenshot.Screenshot

所有这些配置都有插件的plugin.xml文件中的信息

【讨论】:

【参考方案3】:

最简单的方法是使用这个插件:

com.darktalker.cordova.screenshot

【讨论】:

以上是关于如何从 ionic/cordova/phonegap 中的布局截取屏幕截图?的主要内容,如果未能解决你的问题,请参考以下文章

如何将数据从回收器适配器发送到片段 |如何从 recyclerview 适配器调用片段函数

如何从 Firebase 获取所有设备令牌?

如何直接从类调用从接口继承的方法?

如何从服务器获取和设置 android 中的 API(从服务器获取 int 值)?如何绑定和实现这个

如何从Mac从android studio中的fabric注销? [复制]

如何从设备中获取 PDF 文件以便能够从我的应用程序中上传?