如何将照片从图库复制到数据目录?
How to copy a photo from gallery to dataDirectory?
我正在尝试将文件从照片库复制到 Android 5.0 设备上的 dataDirectory。
不幸的是,Cordova 相机插件 returns 路径格式如下: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 的任何想法?
你可以收到base64的图片数据,自己保存。
我在 cordova/HTML5 上做了一个用于轻松管理 FileAPI 的库,也许对你有用:https://github.com/exos/cofs
var fs = new CoFS();
var options = {
quality: 50,
destinationType : navigator.camera.DestinationType.DATA_URL,
sourceType: Camera.PictureSourceType.PHOTOLIBRARY
};
return $cordovaCamera.getPicture(options).then(function (data) {
fs.writeFile(
cordova.file.dataDirectory + '/example.jpg',
data,
'base64',
function (err) {
// if not err, success!
}
);
});
这是你应该如何处理它(使用 fileTransfer plugin instead of 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>
我正在尝试将文件从照片库复制到 Android 5.0 设备上的 dataDirectory。 不幸的是,Cordova 相机插件 returns 路径格式如下: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 的任何想法?
你可以收到base64的图片数据,自己保存。
我在 cordova/HTML5 上做了一个用于轻松管理 FileAPI 的库,也许对你有用:https://github.com/exos/cofs
var fs = new CoFS();
var options = {
quality: 50,
destinationType : navigator.camera.DestinationType.DATA_URL,
sourceType: Camera.PictureSourceType.PHOTOLIBRARY
};
return $cordovaCamera.getPicture(options).then(function (data) {
fs.writeFile(
cordova.file.dataDirectory + '/example.jpg',
data,
'base64',
function (err) {
// if not err, success!
}
);
});
这是你应该如何处理它(使用 fileTransfer plugin instead of 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>