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

當(dāng)時(shí)在開(kāi)發(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格式

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

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

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

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

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

       然后進(jìn)行下面的方法進(jìn)行保存數(shù)據(jù)到本地
這個(gè)是UIWebVIew擴(kuò)展類(lèi),自己寫(xiě)就行
- (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];
}

接著從本地打開(kāi)就ok了.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市忆矛,隨后出現(xiàn)的幾起案子底扳,更是在濱河造成了極大的恐慌寂嘉,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件班挖,死亡現(xiàn)場(chǎng)離奇詭異鲁捏,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)萧芙,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)给梅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)假丧,“玉大人,你說(shuō)我怎么就攤上這事动羽“悖” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵曹质,是天一觀的道長(zhǎng)婴噩。 經(jīng)常有香客問(wèn)我,道長(zhǎng)羽德,這世上最難降的妖魔是什么几莽? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮宅静,結(jié)果婚禮上章蚣,老公的妹妹穿的比我還像新娘。我一直安慰自己姨夹,他們只是感情好纤垂,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著磷账,像睡著了一般峭沦。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上逃糟,一...
    開(kāi)封第一講書(shū)人閱讀 51,727評(píng)論 1 305
  • 那天吼鱼,我揣著相機(jī)與錄音,去河邊找鬼绰咽。 笑死菇肃,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的取募。 我是一名探鬼主播琐谤,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼玩敏!你這毒婦竟也來(lái)了斗忌?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤旺聚,失蹤者是張志新(化名)和其女友劉穎飞蹂,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體翻屈,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡攒磨,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年粱快,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了坦胶。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片敷扫。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖厘贼,靈堂內(nèi)的尸體忽然破棺而出界酒,到底是詐尸還是另有隱情,我是刑警寧澤嘴秸,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布毁欣,位于F島的核電站,受9級(jí)特大地震影響岳掐,放射性物質(zhì)發(fā)生泄漏凭疮。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一串述、第九天 我趴在偏房一處隱蔽的房頂上張望执解。 院中可真熱鬧,春花似錦纲酗、人聲如沸衰腌。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)右蕊。三九已至,卻和暖如春吮螺,著一層夾襖步出監(jiān)牢的瞬間饶囚,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工规脸, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留坯约,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓莫鸭,卻偏偏與公主長(zhǎng)得像闹丐,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子被因,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

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