UIWebView PaginationMode always show white backgro

2019-03-21 13:18发布

I try to use 'paginationMode' to make my html-content pagination for iOS 7 latter.

//set webview to transparent
webView.backgroundColor = [UIColor clearColor];
webView.opaque = NO;

// set multi-columns
webView.paginationBreakingMode = UIWebPaginationBreakingModePage;
webView.paginationMode = UIWebPaginationModeLeftToRight;
webView.pageLength = webView.bounds.size.width;

// set html to transparent background
NSString *transparent = @"addCSSRule('html', 'background-color: transparent')";
[webView stringByEvaluatingJavaScriptFromString:transparent];

but in the end the web view always shows white background, how can I make it transparent?

3条回答
乱世女痞
2楼-- · 2019-03-21 13:45

In case of paginationmode, it's not really working directly from objective c code. However, I got my job done by injecting CSS for 'body' tag:

NSString* path=[[NSBundle mainBundle] pathForResource:@"image" ofType:@"png"];
@"addCSSRule('body', 'background-color: transparent !important; background-image:url(%@); background-repeat: repeat-x; background-size:%fpx %fpx;')",[NSURL fileURLWithPath:path],webView.frame.size.width,webView.frame.size.height];

Note : its for UIWebPaginationModeLeftToRight..

查看更多
时光不老,我们不散
3楼-- · 2019-03-21 13:50

Maybe try to set the background of the scrollView to clear ?

webView.scrollView.backgroundColor = [UIColor clearColor];

EDIT Ok so it seems that after setting

UIWebPaginationMode

The background become white behind :/

查看更多
劫难
4楼-- · 2019-03-21 13:51

Your probably want to provide content background. But the technique of setting webview transparent and providing background color to view behind this may not work well when we use pagination left to right.

I solved this issue by providing content background through CSS and cater the issue of blank area at the end of html content with the help of this post

    - (void)addExtraContentView
{
    UIWebView* wv = self.webView;
    if(!self.viewExtraContent)
    {
        NSString* width = [wv stringByEvaluatingJavaScriptFromString:@"document.documentElement.offsetHeight;"];
        CGFloat contentHeight = [width floatValue];
        CGFloat contentWidth = wv.scrollView.contentSize.width;
        CGFloat y = (int)contentHeight % (int)wv.frame.size.height;
        self.viewExtraContent = [[UIView alloc] initWithFrame:CGRectMake(contentWidth - wv.frame.size.width, y, wv.frame.size.width, (wv.frame.size.height))];
    }
    self.viewExtraContent.backgroundColor = [BookReaderSettings shared].backgroundColor;
    [wv.scrollView addSubview:self.viewExtraContent];
}

And call this method when webview finish loading content.

查看更多
登录 后发表回答