Android 应用内打开Word、Excel、PPT、PDF等文档

Android平台中,可以使用以下几种方式打开Word和Excel文档:

预览图:

一:直接上传给第三方之后用webview打开

        1、微软:

        https://view.officeapps.live.com/op/view.aspx?src=文件链接

        2、XDOC文档预览服务

        http://www.xdocin.com/xdoc?_func=to&_format=html&_cache=true&_xdoc=文件链接

       上面两个链接可以直接放在webview进行加载。

        缺点:文档相当于传递给了第三方,安全性无法保证

二:使用腾讯的X5内核打开

初始化:

        // 设置允许移动网络下进行内核下载。默认不下载
        QbSdk.setDownloadWithoutWifi(true);
        QbSdk.initX5Environment(this, new PreInitCallback() {
            @Override
            public void onCoreInitFinished() {
                // 内核初始化完成,可能为系统内核,也可能为系统内核
            }

            @Override
            public void onViewInitFinished(boolean isX5) {
                Log.e(TAG, "onViewInitFinished: " + isX5);
               
            }
        });

在使用的地方打开文件:

  Bundle localBundle = new Bundle();
         localBundle.putString("filePath", file.toString());
         localBundle.putString("tempPath",
                 tbsReaderTemp);
         if (tbsReaderView == null){
             tbsReaderView = getTbsView();
         }
        //判断是否可以打开文件类型
         boolean result = tbsReaderView.preOpen(FileUtil.getFileType(file.toString()), false);
        Toast.makeText(getApplicationContext(), "预加载结果:" + result, Toast.LENGTH_SHORT).show();
         if (result) {
             tbsReaderView.openFile(localBundle);
         }

官方文档:

腾讯浏览服务

三:使用系统默认的应用打开文档

Android系统默认安装了一些应用,例如WPS Office等,这些应用可以打开常见的Word和Excel文档。如果用户在系统中已经安装了这些应用,可以通过以下代码打开一个文件:

 

java复制代码

String filePath = "/sdcard/test.docx"; Uri uri = Uri.parse("file://" + filePath); Intent intent = new Intent(Intent.ACTION_VIEW); intent.setData(uri); startActivity(intent);

上述代码中,filePath是需要打开的文件路径。使用Uri.parse()方法将其转换成Uri类型,并使用Intent.setAction()方法设置该Intent的操作为ACTION_VIEW。最后使用startActivity()方法启动这个Intent,系统就会根据文件的类型选择合适的应用打开这个文档。

四:使用第三方SDK打开文档

除了系统默认的应用,还可以集成第三方的SDK来打开Word和Excel文档,例如Microsoft Office相关的SDK。这种方式需要开发者首先注册Microsoft的开发者账号,并在开发者控制台中获取相关的权限和应用ID等。在APP中集成SDK之后,可以通过以下代码打开一个文件:

java复制代码

String filePath = "/sdcard/test.docx"; Uri uri = Uri.parse("file://" + filePath); Intent intent = new Intent(Intent.ACTION_VIEW); intent.setData(uri); intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION); intent.addFlags(Intent.FLAG_GRANT_WRITE_URI_PERMISSION); intent.setClassName("com.microsoft.office.word", "com.microsoft.office.word.DocumentActivity"); startActivity(intent);

上述代码中,需要注意的是setClassName()方法,该方法用于设置应用的包名和Activity类名,以便启动对应的应用。此外,还需要添加FLAG_GRANT_READ_URI_PERMISSION和FLAG_GRANT_WRITE_URI_PERMISSION权限,以便应用在打开文件时获取文件读写的权限。

资源下载:https://download.csdn.net/download/YDHIT/87921351

APK:DownLoad

个人中心

好的,以下是一个Java获取各种文档页数的工具类,使用了Apache POI和Apache PDFBox库: ``` import java.io.File; import java.io.FileInputStream; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.apache.poi.hslf.usermodel.HSLFSlideShow; import org.apache.poi.sl.usermodel.SlideShow; import org.apache.poi.hwpf.HWPFDocument; import org.apache.poi.hwpf.usermodel.Range; import org.apache.poi.xslf.usermodel.XMLSlideShow; import org.apache.poi.xwpf.usermodel.XWPFDocument; import org.apache.pdfbox.pdmodel.PDDocument; public class DocumentPageCount { public static int getExcelPageCount(String filePath) { try { File file = new File(filePath); FileInputStream fis = new FileInputStream(file); Workbook workbook = null; if (filePath.endsWith(".xls")) { workbook = new HSSFWorkbook(fis); } else if (filePath.endsWith(".xlsx")) { workbook = new XSSFWorkbook(fis); } fis.close(); return workbook.getNumberOfSheets(); } catch (Exception e) { e.printStackTrace(); return 0; } } public static int getPptPageCount(String filePath) { try { File file = new File(filePath); FileInputStream fis = new FileInputStream(file); SlideShow slideshow = null; if (filePath.endsWith(".ppt")) { slideshow = new HSLFSlideShow(fis); } else if (filePath.endsWith(".pptx")) { slideshow = new XMLSlideShow(fis); } fis.close(); return slideshow.getSlides().size(); } catch (Exception e) { e.printStackTrace(); return 0; } } public static int getWordPageCount(String filePath) { try { File file = new File(filePath); FileInputStream fis = new FileInputStream(file); HWPFDocument doc = null; Range range = null; XWPFDocument docx = null; if (filePath.endsWith(".doc")) { doc = new HWPFDocument(fis); range = doc.getRange(); } else if (filePath.endsWith(".docx")) { docx = new XWPFDocument(fis); range = docx.getDocument().getBody().getDocumentContent().getEndOfContent().getRange(); } fis.close(); return range.numParagraphs(); } catch (Exception e) { e.printStackTrace(); return 0; } } public static int getPdfPageCount(String filePath) { try { File file = new File(filePath); PDDocument document = PDDocument.load(file); int pageCount = document.getNumberOfPages(); document.close(); return pageCount; } catch (Exception e) { e.printStackTrace(); return 0; } } } ``` 这个工具类包含了四个方法,分别用于获取ExcelPPTWordPDF文档的页数。您可以在自己的项目中使用这些方法来获取文档的页数。例如,要获取一个Excel文件的页数,可以调用`DocumentPageCount.getExcelPageCount("path/to/excel/file.xls")`。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Android-Developer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值