iOS--H5界面生成PDF格式進(jìn)行輸出

當(dāng)時(shí)在開發(fā)新版本,領(lǐng)導(dǎo)告訴我們,需要實(shí)現(xiàn)一個(gè)讀取H5界面內(nèi)容,進(jìn)行本地保存PDF格式進(jìn)行觀看.進(jìn)行研究這個(gè)東西.

H5界面生成PDF需要的倆中形式:

  1:圖片的形式的保存.

主要是截取H5界面的所有內(nèi)容,是圖片形式的,然后生成PDF格式.

   2:截取H5界面字符串和圖片

保存的所有的字和圖片,進(jìn)行拼裝,然后以不同樣式進(jìn)行保存PDF格式

第一種方法很只是簡單的操作就可以,但是滿足不了需求,只能選擇第二個(gè).

但是第2個(gè)截取保存數(shù)據(jù)和圖片,自己寫一套的話,工作量很大的.

      利用系統(tǒng)里面的UIWebView

       iOS開發(fā)人員都太熟悉不過了吧,哈哈,都是用這個(gè)方法

      [UIWebView loadHTMLString:@"" baseURL:@""]; 
       進(jìn)行加載H5界面所有文字和圖片.

       然后進(jìn)行下面的方法進(jìn)行保存數(shù)據(jù)到本地
這個(gè)是UIWebVIew擴(kuò)展類,自己寫就行
- (NSData *)converToPDF{

    UIViewPrintFormatter *fmt = [self viewPrintFormatter];

    UIPrintPageRenderer *render = [[UIPrintPageRenderer alloc] init];

    [render addPrintFormatter:fmt startingAtPageAtIndex:0];

    CGRect page;

    page.origin.x=0;

    page.origin.y=0;

    page.size.width=600;

    page.size.height=768;

    CGRect printable=CGRectInset( page, 50, 50 );

    [render setValue:[NSValue valueWithCGRect:page] forKey:@"paperRect"];

    [render setValue:[NSValue valueWithCGRect:printable] forKey:@"printableRect"];

    NSMutableData * pdfData = [NSMutableData data];

    UIGraphicsBeginPDFContextToData( pdfData, CGRectZero, nil );

    for (NSInteger i=0; i < [render numberOfPages]; i++)

    {

        UIGraphicsBeginPDFPage();

        CGRect bounds = UIGraphicsGetPDFContextBounds();

        [render drawPageAtIndex:i inRect:bounds];

    }

    UIGraphicsEndPDFContext();

    return pdfData;

}

//點(diǎn)擊保存進(jìn)行調(diào)用上面的方法
- (void)savePDF
 {
    NSData *data = [_webView converToPDF]; 調(diào)用上面的方法
    NSString *path = [NSHomeDirectory()    stringByAppendingPathComponent:[NSString stringWithFormat:@"Documents/testFile.pdf"]];
    BOOL result = [data writeToFile:path atomically:YES];
    [MBProgressHUD hideHUD];

    if (result) {
       "保存成功"
    }else{
      "保存失敗";
    }
    從本地獲取路徑進(jìn)行顯示PDF
    NSURL *pdfURL = [NSURL fileURLWithPath:path];
    NSURLRequest *request = [NSURLRequest requestWithURL:pdfURL];
    [self.webView setScalesPageToFit:YES];
    [self.webView loadRequest:request];
}

接著從本地打開就ok了.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,063評(píng)論 25 709
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 15,380評(píng)論 4 61
  • 在遇到挫折,還能堅(jiān)持下去繼續(xù)努力的,我想是他對(duì)于這件事的熱愛。這種熱愛能讓他克服碰到的挫折,能給他信心繼續(xù)努力。而...
    有個(gè)歐寶閱讀 331評(píng)論 0 0
  • 需求 項(xiàng)目中需要用到一個(gè)只有返回圖片的返回按鈕 bug演示 說明:這個(gè)bug其實(shí)之前就已經(jīng)存在了,只是現(xiàn)在得到了領(lǐng)...
    AnnieAri閱讀 725評(píng)論 0 0
  • 知道ajax能夠?qū)崿F(xiàn)頁面的局部刷新,大大提升用戶體驗(yàn)。那么在SpringMVC中如何實(shí)現(xiàn)Ajax的請(qǐng)求和響應(yīng)呢?今...
    博為峰51Code教研組閱讀 178評(píng)論 0 1

友情鏈接更多精彩內(nèi)容