javascript - 如何将照片从图库复制到数据目录?

标签 javascript cordova plugins ionic-framework

我正在尝试将文件从照片库复制到 Android 5.0 设备上的 dataDirectory。 不幸的是,Cordova 相机插件以如下格式返回路径:content://media/external/images/media/8793

 var options = {
                quality: 50,
                destinationType: Camera.DestinationType.FILE_URI,
                sourceType: Camera.PictureSourceType.PHOTOLIBRARY,
                saveToPhotoAlbum: false
            };

            return $cordovaCamera.getPicture(options).then(function (result) {
                return handlePictureResult(result);
            })

$cordovaFile.copyFile('content://media/external/images/media/8793', null, cordova.file.dataDirectory, newFileName) 根本不起作用。

关于如何将文件从图库(内容为://)复制到 cordova.file.dataDirectory 有什么想法吗?

最佳答案

这是你应该如何处理它(使用 fileTransfer plugin 而不是 file one ):

app.controller(
    'MainController',
    [
        '$scope', '$cordovaCamera', '$cordovaFileTransfer',
        function($scope, $cordovaCamera, $cordovaFileTransfer)
        {
            $scope.images = { imageUri: '' };

            $scope.getImage = function()
            {
                var options = {
                    quality: 50,
                    destinationType: Camera.DestinationType.FILE_URI,
                    sourceType: Camera.PictureSourceType.PHOTOLIBRARY,
                    saveToPhotoAlbum: false
                };

                $cordovaCamera.getPicture(options).then(
                    function(fileUri)
                    {
                        console.log(fileUri);

                        $cordovaFileTransfer.download(fileUri, cordova.file.dataDirectory + 'my-image.jpg', {}, true).then(
                            function(fileEntry)
                            {
                                $scope.images.imageUri = fileEntry.nativeURL;
                            },
                            function (error)
                            {
                                console.log(error);
                            }
                        );
                    },
                    function(error)
                    {
                        console.log(error);
                    }
                );
            }
        }
    ]
);

还有 HTML(以防万一):

<section ng-controller="MainController">
    <img ng-src="{{ images.imageUri }}">
    <button ng-click="getImage()">GET IMAGE</button>
</section>

关于javascript - 如何将照片从图库复制到数据目录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30785617/

相关文章:

javascript - Google Analytics 异步事件跟踪

javascript - js,根据之前的下拉选项选择输出一个选项下拉列表

ios - Cordova 2.7 - iOS 插件 SQLite exec 已弃用

javascript - iOS 和 Android PhoneGap 应用的订阅模式

eclipse - Subclipse和Tortoise SVN一起

javascript - 如何使用 rollup 将 vuejs 库与我的代码捆绑在一起

javascript - 事件监听器无法一致地工作 Javascript

javascript - 仅在传单和电话间隙中将缩放限制为按钮

java - Eclipse 插件的国际化

c - 如何在 NPAPI C 插件中获取 NPP 实例