9

我正在制作一个 epub 阅读器,我在其中加载 HTML 页面webview

[_webview loadRequest:[NSURLRequest requestWithURL:[NSURL fileURLWithPath:_pagesPath]]];

现在我想更改 HTML 页面的背景颜色和文本颜色。我使用改变了我的 webview 的背景颜色,

self._webview.backgroundColor = [UIColor blackColor];
self._webview.opaque = NO;

那行得通,但我也想更改我的 webview 的文本颜色。我该怎么做呢?

4

6 回答 6

13

在此代码 color:#fff标记中使用文本颜色#fff 使用黑色

NSString *webStr =@"Your text use";

[self._webview  loadHTMLString:[NSString stringWithFormat:@"<div id ='foo' align='left' style='line-height:18px; float:left;width:300px; font-size:13px;font-family:helvetica;background-color:transparent; color:#fff;>%@<div>",webStr] baseURL:nil]; 

如果你使用本地 html使用

 NSString *htmlFile = [[NSBundle mainBundle] pathForResource:@"sample" ofType:@"html"];

NSString* text = [NSString stringWithContentsOfFile:htmlFile encoding:NSUTF8StringEncoding error:nil];
NSLog(@"%@",htmlFile);

NSLog(@"Hello");

[self._webview  loadHTMLString:[NSString stringWithFormat:@"<html><body bgcolor=\"#000000\" text=\"#FFFFFF\" face=\"Bookman Old Style, Book Antiqua, Garamond\" size=\"5\">%@</body></html>", text] baseURL: nil];
于 2012-07-02T10:23:22.957 回答
5
[_webview loadHTMLString:[NSString stringWithFormat:@"<html><body style=\"background-color: white; font-size: 17; font-family: HelveticaNeue; color: #ffffff\">%@</body></html>", strDataFromHTML] baseURL: nil]; 
于 2012-07-02T12:11:48.213 回答
1

我制作了一个方法,它使用给定的正确样式将一些文本包装在 HTML 正文中UIColorUIFont.

只需将生成的 HTML 弹出到 webview 中:

NSString * htmlString = [MyClass htmlFromBodyString:@"an <b>example</b>"
                                           textFont:[UIFont systemFontOfSize:10]
                                          textColor:[UIColor grayColor]];
[webView loadHTMLString:htmlString baseURL:nil];
于 2014-01-30T15:41:28.873 回答
1

这是一个小的 Swift 扩展来处理这个问题:

import UIKit

extension String
{
    func htmlFormattedString(font:UIFont, color: UIColor) -> String
    {
        var numberOfColorComponents:Int = CGColorGetNumberOfComponents(color.CGColor)
        var colorComponents = CGColorGetComponents(color.CGColor)

        var colorHexString = ""
        if numberOfColorComponents == 4 {
            var red = colorComponents[0] * 255
            var green = colorComponents[1] * 255
            var blue = colorComponents[2] * 255

            colorHexString = NSString(format:"%02X%02X%02X", Int(red), Int(green), Int(blue)) as String
        } else if numberOfColorComponents == 2 {
            var white = colorComponents[0] * 255

            colorHexString = NSString(format:"%02X%02X%02X", Int(white), Int(white), Int(white)) as String
        } else {
            return "Color format noch supported"
        }

        return NSString(format: "<html>\n <head>\n <style type=\"text/css\">\n body {font-family: \"%@\"; font-size: %@; color:#%@;}\n </style>\n </head>\n <body>%@</body>\n </html>", font.familyName, String(stringInterpolationSegment: font.pointSize), colorHexString, self) as String
    }
}
于 2015-08-20T07:48:45.467 回答
0

尝试在您的 HTML 文件中添加您从服务器获得的代码...然后只有您可以更改文本颜色...或在您的 HTML 文件之前添加一些 HTML 代码以更改文本颜色

于 2012-07-02T10:23:45.300 回答
-1

试试这个...

  1. 解析 html 文件。
  2. 根据您的要求显示内容。

希望这可以帮助。

于 2012-07-02T11:53:28.223 回答