Для тех, у кого такая же проблема, вот решение.
Решение
Я использую API файловой системы из библиотеки react-native-fetch-blob. Это потому, что я думал, что она лучше документирована и понятна, чем библиотека «react-native-fs».
Я запрашиваю изображение с сервера, получаю base64, а затем сохраняю его в каталоге изображений в файловой системе Android.
Я сохраняю изображение следующим образом:
var RNFetchBlob = require('react-native-fetch-blob').default;
const PictureDir = RNFetchBlob.fs.dirs.PictureDir;
getImageAttachment: function(uri_attachment, filename_attachment, mimetype_attachment) {
return new Promise((RESOLVE, REJECT) => {
// Fetch attachment
RNFetchBlob.fetch('GET', config.apiRoot+'/app/'+uri_attachment)
.then((response) => {
let base64Str = response.data;
let imageLocation = PictureDir+'/'+filename_attachment;
//Save image
fs.writeFile(imageLocation, base64Str, 'base64');
console.log("FILE CREATED!!")
RNFetchBlob.fs.scanFile([ { path : imageLocation, mime : mimetype_attachment } ])
.then(() => {
console.log("scan file success")
})
.catch((err) => {
console.log("scan file error")
})
}).catch((error) => {
// error handling
console.log("Error:", error)
});
},
Следующий код в приведенном выше методе обновляет галерею, иначе изображения не будут отображаться до тех пор, пока телефон не будет выключен и снова включен.
RNFetchBlob.fs.scanFile([ { path : imageLocation, mime : mimetype_attachment } ])
.then(() => {
console.log("scan file success")
})
.catch((err) => {
console.log("scan file error")
})
Наслаждаться!
person
Larney
schedule
09.08.2016