当将 docx 内容转换为 html 并通过 webview 读取时,我一直致力于使用 Docx4j 库读取 Docx 文件。但是,当我尝试在 Android Rich Text Editor 中加载时,相同的 html 代码我没有得到任何格式的文本或图像。我发现 css 样式被注释了,所以我也使用以下代码使用字符串 html 删除了它:
html = html.replace("<!--", "");
html = html.replace("-->", "");
这也没有解决我的问题,我收到了同样没有格式的纯文本。然而,html 包含定义明确的 css 代码。快照
我已经检查过 html 在 RTEditor 中是否有效:
代码:
String subject = "";Spanned description = null;
String message = null;
String signature = null;String withCharacters;
String tsx="";String html = null;
if (savedInstanceState == null) {
Intent intent = getIntent();
subject = getIntent().getStringExtra("textReportFileName");
message = getStringExtra(intent, "message");
signature = getStringExtra(intent, "signature");
mUseDarkTheme = intent.getBooleanExtra("mUseDarkTheme", false);
mSplitToolbar = intent.getBooleanExtra("mSplitToolbar", false);
} else {
subject = savedInstanceState.getString("subject", "");
mUseDarkTheme = savedInstanceState.getBoolean("mUseDarkTheme", false);
mSplitToolbar = savedInstanceState.getBoolean("mSplitToolbar", false);
}
final long startTime = System.currentTimeMillis();
final long endTime;
try {
final LoadFromZipNG loader = new LoadFromZipNG();
WordprocessingMLPackage wordMLPackage = (WordprocessingMLPackage)loader.get(new FileInputStream(new File(Environment.getExternalStorageDirectory()+"/"+getIntent().getStringExtra("textReportFileName"))));
//getIntent().getStringExtra("textReportFileName")
String IMAGE_DIR_NAME = "images";
String baseURL = this.getDir(IMAGE_DIR_NAME, Context.MODE_WORLD_READABLE).toURL().toString();
System.out.println(baseURL); // file:/data/data/com.example.HelloAndroid/app_images/
// Uncomment this to write image files to file system
ConversionImageHandler conversionImageHandler = new AndroidFileConversionImageHandler( IMAGE_DIR_NAME, // <-- don't use a path separator here
baseURL, false, this);
// Uncomment to use a base 64 encoded data URI for each image
// ConversionImageHandler conversionImageHandler = new AndroidDataUriImageHandler();
HtmlExporterNonXSLT withoutXSLT = new HtmlExporterNonXSLT(wordMLPackage, conversionImageHandler);
html = XmlUtils.w3CDomNodeToString(withoutXSLT.export());
html = html.replace("<!--", "");
html = html.replace("-->", "");
withCharacters = StringEscapeUtils.unescapeHtml(html);
description = Html.fromHtml(withCharacters);
//WebView webview = (WebView)this.findViewById(R.id.webpage);
//webview.loadDataWithBaseURL(baseURL, html , "text/html", null, null);
// TabHost mTabHost = getTabHost();
// mTabHost.addTab(mTabHost.newTabSpec("tab_test2").setIndicator("Web Page").setContent(R.id.webpage));
// mTabHost.addTab(mTabHost.newTabSpec("tab_test1").setIndicator("View Source").setContent(tv.getId()));
// mTabHost.setCurrentTab(0);
} catch (Exception e) {
e.printStackTrace();
Toast.makeText(getApplicationContext(),"Invalid Format Exception",Toast.LENGTH_SHORT).show();
} finally {
endTime = System.currentTimeMillis();
}
final long duration = endTime - startTime;
System.err.println("Total time: " + duration + "ms");
message = String.valueOf(description);
Toast.makeText(getApplicationContext(),message,Toast.LENGTH_SHORT).show();
// set theme
setTheme(mUseDarkTheme ? R.style.ThemeDark : R.style.ThemeLight);
super.onCreate(savedInstanceState);
// set layout
setContentView(mSplitToolbar ? R.layout.rte_demo_2 : R.layout.rte_demo_1);
// initialize rich text manager
RTApi rtApi = new RTApi(this, new RTProxyImpl(this), new RTMediaFactoryImpl(this, true));
mRTManager = new RTManager(rtApi, savedInstanceState);
ViewGroup toolbarContainer = (ViewGroup) findViewById(R.id.rte_toolbar_container);
// register toolbar 0 (if it exists)
HorizontalRTToolbar rtToolbar0 = (HorizontalRTToolbar) findViewById(R.id.rte_toolbar);
if (rtToolbar0 != null) {
mRTManager.registerToolbar(toolbarContainer, rtToolbar0);
}
// register toolbar 1 (if it exists)
HorizontalRTToolbar rtToolbar1 = (HorizontalRTToolbar) findViewById(R.id.rte_toolbar_character);
if (rtToolbar1 != null) {
mRTManager.registerToolbar(toolbarContainer, rtToolbar1);
}
// register toolbar 2 (if it exists)
HorizontalRTToolbar rtToolbar2 = (HorizontalRTToolbar) findViewById(R.id.rte_toolbar_paragraph);
if (rtToolbar2 != null) {
mRTManager.registerToolbar(toolbarContainer, rtToolbar2);
}
// set subject
mSubjectField = (EditText) findViewById(R.id.subject);
mSubjectField.setText(subject);
// register message editor
mRTMessageField = (RTEditText) findViewById(R.id.rtEditText_1);
mRTManager.registerEditor(mRTMessageField, true);
if (message != null) {
mRTMessageField.setRichTextEditing(true, message);
}
// register signature editor
mRTSignatureField = (RTEditText) findViewById(R.id.rtEditText_2);
mRTManager.registerEditor(mRTSignatureField, true);
if (signature != null) {
mRTSignatureField.setRichTextEditing(true, signature);
}
mRTMessageField.requestFocus();
}
更新: 我认为编辑器不支持东西。我尝试了下面的简单 html 代码:
<html><head><style>div{background-color: blue}</style></head> <body>Hello <h1>How are you?</h1> <p>My name is <b> Abhishek</b></p><div>Whats up?</div>
它不显示任何内联或外部样式。现在唯一的办法是逐个字符地读取 docx 文件并检查每个字符的字体并将其适本地添加到 RTEditor 中。
最佳答案
富文本编辑器支持readme.md中提到的格式。从 html 到 html 的转换只是为了能够保存和加载编辑的文本,而不是支持每个属性的通用 html 转换器。该组件可以使用任何格式来保存文本(rtf、markdown、您自己命名的格式)。如果你想从 docx 文件导入文本,你必须编写自己的导入/导出转换器,这是可能的。如果你想导入特定的 html 格式,你可以增强现有的 html 转换器(例如,支持样式表中的彩色文本)。您可以导入/转换富文本编辑器支持的所有内容,但尝试导入是没有意义的,例如表格,因为编辑器不支持这些表格(表格没有跨区等效项)。
关于android - Android 富文本编辑器中的 CSS 样式不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31359811/