Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
81413748
D
Docs
项目概览
OpenHarmony
/
Docs
1 年多 前同步成功
通知
159
Star
292
Fork
28
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Docs
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
81413748
编写于
8月 31, 2023
作者:
O
openharmony_ci
提交者:
Gitee
8月 31, 2023
浏览文件
操作
浏览文件
下载
差异文件
!23571 补充修改文管子系统文件相关开发文档
Merge pull request !23571 from 冯俊青/master
上级
c0cefb70
d376951b
变更
9
显示空白变更内容
内联
并排
Showing
9 changed file
with
138 addition
and
106 deletion
+138
-106
zh-cn/application-dev/file-management/app-file-access.md
zh-cn/application-dev/file-management/app-file-access.md
+36
-16
zh-cn/application-dev/file-management/app-file-backup.md
zh-cn/application-dev/file-management/app-file-backup.md
+27
-27
zh-cn/application-dev/file-management/dev-user-file-manager.md
.../application-dev/file-management/dev-user-file-manager.md
+29
-28
zh-cn/application-dev/file-management/file-access-across-devices.md
...ication-dev/file-management/file-access-across-devices.md
+9
-3
zh-cn/application-dev/file-management/manage-external-storage.md
...pplication-dev/file-management/manage-external-storage.md
+12
-9
zh-cn/application-dev/file-management/save-user-file.md
zh-cn/application-dev/file-management/save-user-file.md
+2
-2
zh-cn/application-dev/file-management/select-user-file.md
zh-cn/application-dev/file-management/select-user-file.md
+19
-17
zh-cn/application-dev/file-management/share-app-file.md
zh-cn/application-dev/file-management/share-app-file.md
+2
-2
zh-cn/application-dev/reference/apis/js-apis-file-picker.md
zh-cn/application-dev/reference/apis/js-apis-file-picker.md
+2
-2
未找到文件。
zh-cn/application-dev/file-management/app-file-access.md
浏览文件 @
81413748
...
...
@@ -60,7 +60,13 @@ function createFile() {
console
.
info
(
"
The length of str is:
"
+
writeLen
);
// 从文件读取一段内容
let
arrayBuffer
=
new
ArrayBuffer
(
1024
);
let
readLen
=
fs
.
readSync
(
file
.
fd
,
arrayBuffer
,
{
offset
:
0
});
class
Option
{
public
offset
:
number
=
0
;
public
length
:
number
;
}
let
option
=
new
Option
();
option
.
length
=
arrayBuffer
.
byteLength
;
let
readLen
=
fs
.
readSync
(
file
.
fd
,
arrayBuffer
,
option
);
let
buf
=
buffer
.
from
(
arrayBuffer
,
0
,
readLen
);
console
.
info
(
"
the content of file:
"
+
buf
.
toString
());
// 关闭文件
...
...
@@ -89,11 +95,18 @@ function readWriteFile() {
let
bufSize
=
4096
;
let
readSize
=
0
;
let
buf
=
new
ArrayBuffer
(
bufSize
);
let
readLen
=
fs
.
readSync
(
srcFile
.
fd
,
buf
,
{
offset
:
readSize
});
class
Option
{
public
offset
:
number
=
0
;
public
length
:
number
=
bufSize
;
}
let
option
=
new
Option
();
option
.
offset
=
readSize
;
let
readLen
=
fs
.
readSync
(
srcFile
.
fd
,
buf
,
option
);
while
(
readLen
>
0
)
{
readSize
+=
readLen
;
fs
.
writeSync
(
destFile
.
fd
,
buf
);
readLen
=
fs
.
readSync
(
srcFile
.
fd
,
buf
,
{
offset
:
readSize
});
option
.
offset
=
readSize
;
readLen
=
fs
.
readSync
(
srcFile
.
fd
,
buf
,
option
);
}
// 关闭文件
fs
.
closeSync
(
srcFile
);
...
...
@@ -118,7 +131,7 @@ import common from '@ohos.app.ability.common';
let
context
=
getContext
(
this
)
as
common
.
UIAbilityContext
;
let
filesDir
=
context
.
filesDir
;
async
readWriteFileWithStream
()
{
async
function
readWriteFileWithStream
()
{
// 打开文件流
let
inputStream
=
fs
.
createStreamSync
(
filesDir
+
'
/test.txt
'
,
'
r+
'
);
let
outputStream
=
fs
.
createStreamSync
(
filesDir
+
'
/destFile.txt
'
,
"
w+
"
);
...
...
@@ -126,11 +139,18 @@ async readWriteFileWithStream() {
let
bufSize
=
4096
;
let
readSize
=
0
;
let
buf
=
new
ArrayBuffer
(
bufSize
);
let
readLen
=
await
inputStream
.
read
(
buf
,
{
offset
:
readSize
});
class
Option
{
public
offset
:
number
=
0
;
public
length
:
number
=
bufSize
;
}
let
option
=
new
Option
();
option
.
offset
=
readSize
;
let
readLen
=
await
inputStream
.
read
(
buf
,
option
);
readSize
+=
readLen
;
while
(
readLen
>
0
)
{
await
outputStream
.
write
(
buf
);
readLen
=
await
inputStream
.
read
(
buf
,
{
offset
:
readSize
});
option
.
offset
=
readSize
;
readLen
=
await
inputStream
.
read
(
buf
,
option
);
readSize
+=
readLen
;
}
// 关闭文件流
...
...
@@ -157,17 +177,17 @@ let filesDir = context.filesDir;
// 查看文件列表
function
getListFile
()
{
let
filter
:
Filter
=
{
suffix
:
[
'
.png
'
,
'
.jpg
'
,
'
.txt
'
],
// 匹配文件后缀名为'.png','.jpg','.txt'
displayName
:
[
'
test%
'
],
// 匹配文件全名以'test'开头
fileSizeOver
:
0
,
// 匹配文件大小大于等于0
lastModifiedAfter
:
new
Date
(
0
).
getTime
(),
// 匹配文件最近修改时间在1970年1月1日之后
class
ListFileOption
{
public
recursion
:
boolean
=
false
;
public
listNum
:
number
=
0
;
public
filter
:
Filter
}
let
files
=
fs
.
listFileSync
(
filesDir
,
{
recursion
:
false
,
listNum
:
0
,
filter
:
filter
});
let
option
=
new
ListFileOption
();
option
.
filter
.
suffix
=
[
'
.png
'
,
'
.jpg
'
,
'
.txt
'
];
// 匹配文件后缀名为'.png','.jpg','.txt'
option
.
filter
.
displayName
=
[
'
test%
'
];
// 匹配文件全名以'test'开头
option
.
filter
.
fileSizeOver
=
0
;
// 匹配文件全名以'test'开头
option
.
filter
.
lastModifiedAfter
=
new
Date
(
0
).
getTime
();
// 匹配文件最近修改时间在1970年1月1日之后
let
files
=
fs
.
listFileSync
(
filesDir
,
option
);
for
(
let
i
=
0
;
i
<
files
.
length
;
i
++
)
{
console
.
info
(
`The name of file:
${
files
[
i
]}
`
);
}
...
...
zh-cn/application-dev/file-management/app-file-backup.md
浏览文件 @
81413748
...
...
@@ -107,7 +107,7 @@
// 创建SessionBackup类的实例用于备份数据
let
g_session
:
backup
.
SessionBackup
;
function
createSessionBackup
()
{
let
sessionBackup
=
new
backup
.
SessionBackup
(
{
let
generalCallbacks
:
backup
.
GeneralCallbacks
=
{
onFileReady
:
(
err
:
BusinessError
,
file
:
backup
.
File
)
=>
{
if
(
err
)
{
console
.
info
(
'
onFileReady err:
'
+
JSON
.
stringify
(
err
));
...
...
@@ -148,7 +148,8 @@
onBackupServiceDied
:
()
=>
{
console
.
info
(
'
onBackupServiceDied
'
);
},
});
}
let
sessionBackup
=
new
backup
.
SessionBackup
(
generalCallbacks
);
return
sessionBackup
;
}
...
...
@@ -181,13 +182,14 @@
// 创建SessionRestore类的实例用于恢复数据
let
g_session
:
backup
.
SessionRestore
;
async
function
publishFile
(
file
:
backup
.
File
)
{
await
g_session
.
publishFile
(
{
let
fileMeta
:
backup
.
FileMeta
=
{
bundleName
:
file
.
bundleName
,
uri
:
file
.
uri
});
}
await
g_session
.
publishFile
(
fileMeta
);
}
function
createSessionRestore
()
{
let
sessionRestore
=
new
backup
.
SessionRestore
(
{
let
generalCallbacks
:
backup
.
GeneralCallbacks
=
{
onFileReady
:
(
err
:
BusinessError
,
file
:
backup
.
File
)
=>
{
if
(
err
)
{
console
.
info
(
'
onFileReady err:
'
+
JSON
.
stringify
(
err
));
...
...
@@ -224,7 +226,8 @@
onBackupServiceDied
:
()
=>
{
console
.
info
(
'
service died
'
);
}
});
}
let
sessionRestore
=
new
backup
.
SessionRestore
(
generalCallbacks
);
return
sessionRestore
;
}
...
...
@@ -240,14 +243,13 @@
console
.
info
(
'
appendBundles success
'
);
// 添加需要恢复的应用成功后,请根据需要恢复的应用名称,调用getFileHandle接口获取待恢复应用数文件的文件句柄
// 应用待恢复数据文件数请依据实际备份文件个数为准,此处仅为请求示例
await
g_session
.
getFileHandle
(
{
let
handle
:
backup
.
FileMeta
=
{
bundleName
:
restoreApps
[
0
],
uri
:
"
manage.json
"
});
await
g_session
.
getFileHandle
({
bundleName
:
restoreApps
[
0
],
uri
:
"
1.tar
"
});
}
await
g_session
.
getFileHandle
(
handle
);
handle
.
uri
=
"
1.tar
"
;
await
g_session
.
getFileHandle
(
handle
);
console
.
info
(
'
getFileHandle success
'
);
}
```
...
...
@@ -274,13 +276,14 @@
// 创建SessionRestore类的实例用于恢复数据
let
g_session
:
backup
.
SessionRestore
;
async
function
publishFile
(
file
:
backup
.
File
)
{
await
g_session
.
publishFile
(
{
let
fileMeta
:
backup
.
FileMeta
=
{
bundleName
:
file
.
bundleName
,
uri
:
file
.
uri
});
}
await
g_session
.
publishFile
(
fileMeta
);
}
function
createSessionRestore
()
{
let
sessionRestore
=
new
backup
.
SessionRestore
(
{
let
generalCallbacks
:
backup
.
GeneralCallbacks
=
{
onFileReady
:
(
err
:
BusinessError
,
file
:
backup
.
File
)
=>
{
if
(
err
)
{
console
.
info
(
'
onFileReady err:
'
+
JSON
.
stringify
(
err
));
...
...
@@ -322,7 +325,8 @@
onBackupServiceDied
:
()
=>
{
console
.
info
(
'
service died
'
);
}
});
}
let
sessionRestore
=
new
backup
.
SessionRestore
(
generalCallbacks
);
return
sessionRestore
;
}
...
...
@@ -342,19 +346,15 @@
console
.
info
(
'
appendBundles success
'
);
// 开发者需要请求安装应用的文件句柄
await
g_session
.
getFileHandle
(
{
let
handle
:
backup
.
FileMeta
=
{
bundleName
:
restoreApps
[
0
],
uri
:
"
/data/storage/el2/restore/bundle.hap
"
});
await
g_session
.
getFileHandle
({
bundleName
:
restoreApps
[
0
],
uri
:
"
manage.json
"
});
await
g_session
.
getFileHandle
({
bundleName
:
restoreApps
[
0
],
uri
:
"
1.tar
"
});
}
await
g_session
.
getFileHandle
(
handle
);
handle
.
uri
=
"
manage.json
"
;
await
g_session
.
getFileHandle
(
handle
);
handle
.
uri
=
"
1.tar
"
;
await
g_session
.
getFileHandle
(
handle
);
console
.
info
(
'
getFileHandle success
'
);
}
```
...
...
zh-cn/application-dev/file-management/dev-user-file-manager.md
浏览文件 @
81413748
...
...
@@ -24,6 +24,7 @@ OpenHarmony预置了FileManager文件管理器。系统应用开发者也可以
import
fileExtensionInfo
from
'
@ohos.file.fileExtensionInfo
'
;
import
{
Filter
}
from
'
@ohos.file.fs
'
;
import
common
from
'
@ohos.app.ability.common
'
;
import
{
BusinessError
}
from
'
@ohos.base
'
;
```
其中fileAccess提供了文件基础操作的API,fileExtensionInfo提供了应用开发的关键结构体。
...
...
@@ -45,13 +46,14 @@ OpenHarmony预置了FileManager文件管理器。系统应用开发者也可以
if
(
!
fileAccessHelperAllServer
)
{
console
.
error
(
"
createFileAccessHelper interface returns an undefined object
"
);
}
}
catch
(
error
)
{
}
catch
(
err
)
{
let
error
:
BusinessError
=
err
as
BusinessError
;
console
.
error
(
"
createFileAccessHelper failed, errCode:
"
+
error
.
code
+
"
, errMessage:
"
+
error
.
message
);
}
}
let
rootInfos
:
Array
<
fileAccess
.
RootInfo
>
=
[];
async
function
getRoots
()
{
let
rootIterator
:
fileAccess
.
RootIterator
;
let
rootInfos
:
fileAccess
.
RootInfo
[]
=
[];
let
isDone
:
boolean
=
false
;
try
{
rootIterator
=
await
fileAccessHelperAllServer
.
getRoots
();
...
...
@@ -81,7 +83,7 @@ OpenHarmony预置了FileManager文件管理器。系统应用开发者也可以
```
ts
// 从根目录开始
let
rootInfo
=
rootInfos
[
0
];
let
fileInfos
:
fileAccess
.
FileInfo
[]
=
[];
let
fileInfos
:
Array
<
fileAccess
.
FileInfo
>
=
[];
let
isDone
:
boolean
=
false
;
let
filter
:
Filter
=
{
suffix
:
[
"
.txt
"
,
"
.jpg
"
,
"
.xlsx
"
]};
// 设定过滤条件
try
{
...
...
@@ -89,7 +91,6 @@ OpenHarmony预置了FileManager文件管理器。系统应用开发者也可以
// let fileIterator = rootInfo.scanFile(filter); // 过滤设备rootinfos[0]满足指定条件的文件信息,返回迭代对象
if
(
!
fileIterator
)
{
console
.
error
(
"
listFile interface returns an undefined object
"
);
return
;
}
while
(
!
isDone
)
{
let
result
=
fileIterator
.
next
();
...
...
@@ -105,21 +106,20 @@ OpenHarmony预置了FileManager文件管理器。系统应用开发者也可以
// 从指定的目录开始
let
fileInfoDir
=
fileInfos
[
0
];
// fileInfoDir 表示某个目录信息
let
subFileInfos
:
fileAccess
.
FileInfo
[]
=
[];
let
isDone
:
boolean
=
false
;
let
filter
:
Filter
=
{
suffix
:
[
"
.txt
"
,
"
.jpg
"
,
"
.xlsx
"
]};
// 设定过滤条件
let
subFileInfos
:
Array
<
fileAccess
.
FileInfo
>
=
[];
let
isDone
02
:
boolean
=
false
;
let
filter
02
:
Filter
=
{
suffix
:
[
"
.txt
"
,
"
.jpg
"
,
"
.xlsx
"
]};
// 设定过滤条件
try
{
let
fileIterator
=
fileInfoDir
.
listFile
();
// 遍历特定的目录fileinfo,返回迭代器对象
// let fileIterator = rootInfo.scanFile(filter); // 过滤特定的目录fileinfo,返回迭代器对象
// let fileIterator = rootInfo.scanFile(filter
02
); // 过滤特定的目录fileinfo,返回迭代器对象
if
(
!
fileIterator
)
{
console
.
error
(
"
listFile interface returns an undefined object
"
);
return
;
}
while
(
!
isDone
)
{
while
(
!
isDone
02
)
{
let
result
=
fileIterator
.
next
();
console
.
info
(
"
next result =
"
+
JSON
.
stringify
(
result
));
isDone
=
result
.
done
;
if
(
!
isDone
)
isDone
02
=
result
.
done
;
if
(
!
isDone
02
)
subFileInfos
.
push
(
result
.
value
);
}
}
catch
(
err
)
{
...
...
@@ -136,19 +136,20 @@ OpenHarmony预置了FileManager文件管理器。系统应用开发者也可以
// 创建文件
// 示例代码sourceUri是Download目录的fileinfo中的URI
// 开发者应根据自己实际获取fileinfo的URI进行开发
async
function
creatFile
()
{
let
sourceUri
:
string
=
"
file://docs/storage/Users/currentUser/Download
"
;
let
displayName
:
string
=
"
file1
"
;
let
fileUri
:
string
;
try
{
// fileAccessHelp
er 参考 fileAccess.createFileAccessHelper 示例代码获取
fileUri
=
await
fileAccessHelp
er
.
createFile
(
sourceUri
,
displayName
);
// fileAccessHelperAllServ
er 参考 fileAccess.createFileAccessHelper 示例代码获取
fileUri
=
await
fileAccessHelperAllServ
er
.
createFile
(
sourceUri
,
displayName
);
if
(
!
fileUri
)
{
console
.
error
(
"
createFile return undefined object
"
);
return
;
}
console
.
info
(
"
createFile sucess, fileUri:
"
+
JSON
.
stringify
(
fileUri
));
}
catch
(
err
)
{
let
error
:
BusinessError
=
err
as
BusinessError
;
console
.
error
(
"
createFile failed, errCode:
"
+
error
.
code
+
"
, errMessage:
"
+
error
.
message
);
};
}
```
zh-cn/application-dev/file-management/file-access-across-devices.md
浏览文件 @
81413748
...
...
@@ -15,6 +15,7 @@
```
ts
import
fs
from
'
@ohos.file.fs
'
;
import
common
from
'
@ohos.app.ability.common
'
;
import
{
BusinessError
}
from
'
@ohos.base
'
;
let
context
=
getContext
(
this
)
as
common
.
UIAbilityContext
;
// 获取设备A的UIAbilityContext信息
let
pathDir
:
string
=
context
.
distributedFilesDir
;
...
...
@@ -41,6 +42,7 @@
import
fs
from
'
@ohos.file.fs
'
;
import
common
from
'
@ohos.app.ability.common
'
;
import
buffer
from
'
@ohos.buffer
'
;
import
{
BusinessError
}
from
'
@ohos.base
'
;
let
context
=
getContext
(
this
)
as
common
.
UIAbilityContext
;
// 获取设备B的UIAbilityContext信息
let
pathDir
:
string
=
context
.
distributedFilesDir
;
...
...
@@ -53,9 +55,13 @@
// 定义接收读取数据的缓存
let
arrayBuffer
=
new
ArrayBuffer
(
4096
);
// 读取文件的内容,返回值是读取到的字节个数
let
num
=
fs
.
readSync
(
file
.
fd
,
arrayBuffer
,
{
offset
:
0
});
class
Option
{
public
offset
:
number
=
0
;
public
length
:
number
;
}
let
option
=
new
Option
();
option
.
length
=
arrayBuffer
.
byteLength
;
let
num
=
fs
.
readSync
(
file
.
fd
,
arrayBuffer
,
option
);
// 打印读取到的文件数据
let
buf
=
buffer
.
from
(
arrayBuffer
,
0
,
num
);
console
.
info
(
'
read result:
'
+
buf
.
toString
());
...
...
zh-cn/application-dev/file-management/manage-external-storage.md
浏览文件 @
81413748
...
...
@@ -57,6 +57,8 @@
import
volumeManager
from
'
@ohos.file.volumeManager
'
;
import
{
BusinessError
}
from
'
@ohos.base
'
;
let
subscriber
:
CommonEvent
.
CommonEventSubscriber
;
async
function
example
()
{
const
subscribeInfo
:
CommonEvent
.
CommonEventSubscribeInfo
=
{
events
:
[
"
usual.event.data.VOLUME_REMOVED
"
,
...
...
@@ -66,7 +68,8 @@
"
usual.event.data.VOLUME_EJECT
"
]
};
let
subscriber
=
await
CommonEvent
.
createSubscriber
(
subscribeInfo
);
subscriber
=
await
CommonEvent
.
createSubscriber
(
subscribeInfo
);
}
```
3.
收到广播通知后获取卷设备信息。
...
...
zh-cn/application-dev/file-management/save-user-file.md
浏览文件 @
81413748
...
...
@@ -62,8 +62,8 @@ save接口会将文件保存在文件管理器,而不是图库。
save返回的uri权限是读写权限,可以根据结果集里面的uri进行文件读写等操作。注意不能在picker的回调里直接使用此uri进行打开文件操作,需要定义一个全局变量保存uri,使用类似一个按钮去触发打开文件。
```
ts
let
uris
:
string
;
async
photoViewPickerSave
()
{
let
uris
:
Array
<
string
>
;
async
function
photoViewPickerSave
()
{
try
{
const
photoSaveOptions
=
new
picker
.
PhotoSaveOptions
();
// 创建文件管理器保存选项实例
photoSaveOptions
.
newFileNames
=
[
"
PhotoViewPicker01.png
"
];
// 保存文件名(可选),方括号里的文件名自定义,每次不能重复,设备里已有这个文件的话,名字就需要改个不一样的,不然接口会报错
...
...
zh-cn/application-dev/file-management/select-user-file.md
浏览文件 @
81413748
...
...
@@ -107,6 +107,7 @@
> 目前DocumentSelectOptions功能不完整, 如需获取文件名称,请使用startAbilityForResult接口。
```
ts
async
function
example
()
{
let
config
:
Want
=
{
action
:
'
ohos.want.action.OPEN_FILE
'
,
parameters
:
{
...
...
@@ -123,10 +124,11 @@
let
select_item_list
=
result
.
want
.
parameters
.
select_item_list
;
// 获取到文档文件的文件名称
let
file_name_list
=
result
.
want
.
parameters
.
file_name_list
;
}
catch
(
er
r
)
{
}
catch
(
erro
r
)
{
let
err
:
BusinessError
=
error
as
BusinessError
;
console
.
error
(
`Invoke documentViewPicker.select failed, code is
${
err
.
code
}
, message is
${
err
.
message
}
`
);
}
}
```
4.
待界面从FilePicker返回后,再通过类似一个按钮调用其他函数,使用
[
fs.openSync
](
../reference/apis/js-apis-file-fs.md#fsopensync
)
接口,通过uri打开这个文件得到fd。这里需要注意接口权限参数是fs.OpenMode.READ_ONLY。
...
...
zh-cn/application-dev/file-management/share-app-file.md
浏览文件 @
81413748
...
...
@@ -79,8 +79,7 @@
console
.
error
(
`Invoke startAbility failed, code is
${
err
.
code
}
, message is
${
err
.
message
}
`
);
});
}
...
// ...
}
```
...
...
@@ -123,6 +122,7 @@
// xxx.ets
import
fs
from
'
@ohos.file.fs
'
;
import
Want
from
'
@ohos.app.ability.Want
'
;
import
{
BusinessError
}
from
'
@ohos.base
'
;
function
getShareFile
()
{
try
{
...
...
zh-cn/application-dev/reference/apis/js-apis-file-picker.md
浏览文件 @
81413748
...
...
@@ -65,7 +65,7 @@ async function example01() {
});
}
catch
(
error
)
{
let
err
:
BusinessError
=
error
as
BusinessError
;
console
.
error
(
'
PhotoViewPicker failed with err:
'
+
+
JSON
.
stringify
(
err
));
console
.
error
(
'
PhotoViewPicker failed with err:
'
+
JSON
.
stringify
(
err
));
}
}
```
...
...
@@ -207,7 +207,7 @@ async function example05() {
let
photoPicker
=
new
picker
.
PhotoViewPicker
();
photoPicker
.
save
(
PhotoSaveOptions
,
(
err
:
BusinessError
,
PhotoSaveResult
:
Array
<
string
>
)
=>
{
if
(
err
)
{
console
.
error
(
'
PhotoViewPicker.save failed with err:
'
JSON
.
stringify
(
err
));
console
.
error
(
'
PhotoViewPicker.save failed with err:
'
+
JSON
.
stringify
(
err
));
return
;
}
console
.
info
(
'
PhotoViewPicker.save successfully, PhotoSaveResult uri:
'
+
JSON
.
stringify
(
PhotoSaveResult
));
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录