• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

ios - 如何从 ionic/cordova/phonegap 中的布局截屏?

[复制链接]
菜鸟教程小白 发表于 2022-12-13 11:50:20 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

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



Best Answer-推荐答案


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

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/

关于ios - 如何从 ionic/cordova/phonegap 中的布局截屏?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33054248/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap