整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          如何在 Java 中將 HTML 轉換為 PNG

          日分享最新,最流行的軟件開發知識與最新行業趨勢,希望大家能夠一鍵三連,多多支持,跪求關注,點贊,留言。

          本文討論了對 HTML 代碼可視化文檔的需求,并提供了一個免費的 API 解決方案,可將 HTML 字符串轉換為 PNG 屏幕截圖。

          自 20 世紀 80 年代后期的構想以來,超文本標記語言 (HTML) 一直是在線顯示網頁的關鍵元素。這種無處不在的編程語言繼續提供詳細的框架,用于構建我們在 Web 上看到和交互的內容,允許我們以純文本代碼格式化文本和多媒體組件,這很簡單,可以在需要時進行更改。
          HTML 的轉變
          與幾乎所有編程語言的情況一樣,HTML自推出以來的幾十年中已經轉變為包含許多新功能,以適應典型的當代壓力,例如社區反饋/批評和相鄰 Web 開發技術的快速發展。在現代 HTML 代碼的輸出中,我們可以很容易地看到這種轉換的結果;例如,最近的 HTML 迭代——HTML5,于 2014 年推出——提供了用于嵌入視頻和音頻文件的新的、簡單的元素,以及移動顯示和整體移動功能中急需的改進。

          當然,新元素和顯示質量的改進并不是網站的 HTML 代碼會隨著時間的推移可靠地改變的唯一原因。網站不斷設計和重新設計,可能是為了創新,也是為了響應用戶反饋產生的趨勢。例如,2014 年開發的網站很可能融合了各種當代設計趨勢,而與當年 HTML5 中引入的變化無關。在該項目之后的幾年里,該網站的開發人員可能會發現自己至少多次重復了他們的 HTML 代碼的一部分,同時一直在為不可避免的 HTML6 發布和最終合并其新的和改進的功能而構建。

          鑒于 HTML 開發中的這些自然進展,出現了一個重要問題:我們如何有效地跟蹤和記錄我們網站 HTML 代碼的增長?考慮到 HTML 輸出的固有視覺特性,答案相對簡單。我們可以輕松地以靜態二維圖像文件(屏幕截圖)的形式存儲 HTML 網站的迭代,并且我們可以相對輕松地以編程方式完成此轉換。

          網頁截圖
          捕獲 HTML 屏幕截圖具有大量實際的業務應用程序。當為網站編寫新的 HTML 代碼時,渲染該 HTML 代碼輸出的圖像作為一種簡單、易于共享的“狀態檢查”,用于檢查其內容在給定時間點如何顯示在 Web 瀏覽器上。出于同樣的原因,這樣的屏幕截圖提供了一種極好的方法來快速測試 HTML 代碼的新的、實驗性的迭代,使開發人員可以輕松地創建和存儲開發中項目的各種版本——包括成功的和不成功的。屏幕截圖還為實時網站中不可避免的問題提供了一種理想的可視化記錄方式,從而更容易跟蹤棘手的問題并跟蹤它們在不同設備、瀏覽器或操作系統上的顯示方式。

          教程
          本教程的目的是提供一個簡單、免費、易于使用的 API 解決方案,用于在 Java 中將 HTML 字符串轉換為 PNG 屏幕截圖。此 API 將完整呈現網站,返回 HTML 在常規 Web 瀏覽器視圖中顯示內容的屏幕截圖。它支持所有現代、高級的 Web 開發功能,包括與 HTML5、CSS、JavaScript等相關的功能。為方便起見,頁面下方提供了現成的 Java 代碼示例,以幫助您輕松構建 API 調用。

          該接口有兩個必填的請求參數,包括以下內容:

          你的 HTML 字符串
          一個免費的 Cloudmersive API 密鑰(您可以通過訪問我們的網站并注冊一個免費帳戶來獲得一個)。
          除了上述強制輸入外,此 API 還提供了幾個可選參數,允許進一步自定義您的輸入請求。這些可選參數包括以下內容:

          Extra loading wait:網頁完成加載后截屏前等待的額外毫秒數(對于非常異步的網站很有幫助)。
          屏幕截圖高度:屏幕截圖的所需高度,以像素表示(默認為 1280 x 1024)。提供整數“0”會觸發默認設置,而提供整數“-1”會要求 API 測量并嘗試屏幕高度屏幕截圖。
          屏幕截圖寬度:屏幕截圖的所需寬度,以像素表示(也默認為標準 1280 x 1024 測量值)。提供整數“0”或“-1”會產生與上述“屏幕截圖高度”參數中所述相同的結果。
          在其響應中,此 API 將提供一個包含新 PNG 文件編碼的字符串。

          要在Java中構建 API 調用,第一步是安裝 SDK。這可以使用 Maven 來完成,方法是首先將以下引用添加到存儲庫中pom.xml:

          <repositories>
          <repository>
          <id>jitpack.io</id>
          <url>https://jitpack.io</url>
          </repository>
          </repositories>



          之后,將下面的引用添加到依賴項中pom.xml:

          <dependencies>
          <dependency>
          <groupId>com.github.Cloudmersive</groupId>
          <artifactId>Cloudmersive.APIClient.Java</artifactId>
          <version>v4.25</version>
          </dependency>
          </dependencies>



          要改為使用 Gradle 安裝SDK,請在根目錄build.gradle(存儲庫末尾)中添加您的引用:

          allprojects {
          repositories {
          ...
          maven { url 'https://jitpack.io' }
          }
          }


          然后添加依賴項build.gradle:

          dependencies {
          implementation 'com.github.Cloudmersive:Cloudmersive.APIClient.Java:v4.25'
          }


          安裝完成后,剩下的就是復制并粘貼以下代碼示例,并完成如上所述的強制和可選請求參數:

          // Import classes:
          //import com.cloudmersive.client.invoker.ApiClient;
          //import com.cloudmersive.client.invoker.ApiException;
          //import com.cloudmersive.client.invoker.Configuration;
          //import com.cloudmersive.client.invoker.auth.*;
          //import com.cloudmersive.client.ConvertWebApi;

          ApiClient defaultClient = Configuration.getDefaultApiClient();

          // Configure API key authorization: Apikey
          ApiKeyAuth Apikey = (ApiKeyAuth) defaultClient.getAuthentication("Apikey");
          Apikey.setApiKey("YOUR API KEY");
          // Uncomment the following line to set a prefix for the API key, e.g. "Token" (defaults to null)
          //Apikey.setApiKeyPrefix("Token");

          ConvertWebApi apiInstance = new ConvertWebApi();
          HtmlToPngRequest input = new HtmlToPngRequest(); // HtmlToPngRequest | HTML to PNG request parameters
          try {
          byte[] result = apiInstance.convertWebHtmlToPng(input);
          System.out.println(result);
          } catch (ApiException e) {
          System.err.println("Exception when calling ConvertWebApi#convertWebHtmlToPng");
          e.printStackTrace();
          }


          一旦你完成了這一步,你就大功告成了——你現在可以調用這個 API 并輕松地將 HTML 字符串呈現為 PNG 屏幕截圖。

          注意: 您的免費層級 API 密鑰將提供每月 800 次 API 調用的限制,無需承諾。一旦達到該限制,您的總數將在下個月重置。

          016年7月中旬:

          ——這陣子淘寶H5很火,朋友圈被刷了好幾天屏。這不是一般的720度全景,它有偽3D的VR效果!你能上下、左右滑動看到不同視角的畫面,還能玩重力感應。對了那些動漫人物,動起來是分前后的!聽說淘寶請外包團隊,花了30萬。

          ——哦?以后不用了。

          ▲淘寶H5原版

          2個禮拜后:

          7月28日上午,iH5.cn主頁悄悄更新系統消息:“全景功能上線,可制作720VR瀏覽效果”。一下放出3個全景組件,720度VR、重力感應、頁面交互,各種功能1個不落!(在此感謝原作者Shrek公開了核心源碼)

          你是說我們不花一分錢能做出淘寶的H5?

          這是真的,我已經把這個H5做出來了:

          ▲淘寶H5致敬版

          相似度:95%

          你也要玩玩嗎?過程簡單得可怕,只有3步——

          (1)準備全景素材

          ▲淘寶H5的圖片

          A、1張首尾相連的全景圖,當背景;

          B、堆疊在全景圖上的人或物件的PNG圖,當前景。

          為方便演示,這里直接扒淘寶造物節80張切好的圖,拼合成不同的層。上面半透明的背景是20張切片合成的,前景大概照著淘寶H5的位置放,共分成3層(NO.1最靠前)。

          (2)用Photoshop切圖

          A、把不同層的圖片各豎切成N份,然后導出;

          B、導出時,越靠后層的圖片寬度(W)要越大。

          不會切圖勞煩百度,我這里把1張背景、3張前景分別切20塊導出為PNG。切的份數越多,三維效果就越平滑,但圖片也會隨著變大容易卡。

          (3)用iH5做全景運動

          ▲用iH5設置交互

          A、新建全景容器,下面放4個全景背景組;

          B、把切好的分層切片分別拖到對應的全景背景組里。

          比如你要放背景層圖片,就保持全景背景組1選中,把20張切片拖到頁面里就行。見證奇跡的時刻到了!以下幾張圖比較高能,是拖好圖調試的效果,強烈建議有WIFI的人點開:

          ▲用iH5分別調試水平轉角、垂直仰角、觀察點大小的效果

          看完上面圖片你應該也懂了,每個全景組就是把切片按順序圍成圓柱。

          那剛才給前后層圖片設不一樣的寬度,用處是?寬度越小,圍成圓的周長就越小,當觀察點在圓的中心,就會感覺這一層離得越近、移動得越快——VR的立體效果就這么來的。

          [注]半徑=周長/2π,相減可推測不同層的間距,并判斷觀察點的合適位置。

          如果你對點擊彈出華晨宇的新歌介紹、H5上方飄著一個造物節LOGO、滑動頁面畫面會伸縮什么的感興趣,直接去官網找教學視頻吧。

          加全景和調試其實很快,30分鐘不到,主要時間都花在處理淘寶那些素材了……扒人家原圖重新拼合構圖再切開很費事啊,還是原創好。

          因為模仿出來的H5太像了,為避免侵權不敢發出來給大家看。你自己試試吧?

          用HTML5分片上傳超大文件思路,WEBUPLOADER 支持 超大上G,多附件上傳,JS 大文件分割/分片上傳,百度WEBUPLOADER上傳視頻等大文件,WEBUPLOAD組件實現文件上傳功能和下載功能,JS大文件切片上傳,斷點續傳實現DEMO,前端上傳大文件的解決方案,前端上傳大文件處理(切片、斷點續傳),前端大文件上傳優化方案——分片上傳,vue大文件上傳解決方案,vue大文件上傳解決方案10G,vue大文件上傳解決方案50G,vue大文件上傳解決方案100G,html5如何實現大文件斷點續傳、秒傳,

          java如何實現大文件斷點續傳、秒傳,SpringBoot如何實現大文件斷點續傳、秒傳,SpringMVC如何實現大文件斷點續傳、秒傳,SpringCloud如何實現大文件斷點續傳、秒傳,

          webuploader如何實現大文件斷點續傳、秒傳,百度webuploader如何實現大文件斷點續傳、秒傳,html5實現大文件斷點續傳、秒傳,vue如何實現大文件斷點續傳、秒傳,前端如何實現大文件斷點續傳、秒傳,JavaScript如何實現大文件斷點續傳、秒傳,

          html5大文件斷點續傳、秒傳解決方案,html5大文件斷點續傳、加密上傳解決方案,html5大文件斷點續傳、加密存儲解決方案,html5大文件斷點續傳分片解決方案,html5大文件斷點續傳分塊解決方案,html5大文件斷點續傳分割解決方案,html5大文件斷點續傳切割解決方案,

          給政府做的一個項目。實際上客戶那邊對具體的技術實際不關心。

          研發部門的同事調研過百度的webuploader這個組件,發現他實際上就是對Flash和HTML5進行了一個封裝,本質還是調的HTML5的API,之前在項目中也用過,嘗試過,但是最終都不太滿意,一個是兼容性非常差,說的是兼容IE,但是在IE用的是Flash,在很多用戶的電腦上用不了,卡頓崩潰發生的太頻繁,文件上傳的數量一多比如幾千個,前端頁面就開始卡了,用戶體驗非常差。這些問題研發部的同事都向百度反應過,但是百度webuploader那邊一直沒人回,基本上沒人管,領導說要求付費提供技術支持,那邊也是沒人回,聯系不上他們任何人。

          webuploader這邊連個開發人員都聯系不到,這個是怎么回事?

          搞的我們領導現在基本上不怎么考慮國內這些免費開源的項目,研發部門的同事稱這些項目為免費坑人項目。

          用戶上傳的文件比較大,有20G左右,直接用HTML傳的話容易失敗,服務器也容易出錯,需要分片,分塊,分割上傳。也就是將一個大的文件分成若干個小文件塊來上傳,另外就是需要實現秒傳功能和防重復功能,秒傳就是用戶如果上傳過這個文件,那么直接在數據庫中查找記錄就行了,不用再上傳一次,節省時間,實現的思路是對文件做MD5計算,將MD5值保存到數據庫,算法可以用MD5,或者CRC,或者SHA1,這個隨便哪個算法都行。

          分片還需要支持斷點續傳,現在HTML5雖然提供了信息記錄功能,但是只支持到了會話級,也就是用戶不能關閉瀏覽器,也不能清空緩存。但是有的政府單位上傳大文件,傳了一半下班了,明天繼續傳,電腦一關結果進度信息就丟失了,這個是他們的一個痛點。

          切片的話還有一點就是在服務器上合并,一個文件的所有分片數據上傳完后需要在服務器端進行合并操作。

          聊下HTML5吧,怎么說呢,HTML5也就是chrome提供的一個API來實現文件分片,反正基本的需求,小文件用是能用,但是用起來多多少少還是有點別扭,擴展性,安全性,穩定性用戶那陣都不太滿意,關鍵是什么,我們是沒辦法對HTML5進行擴展,個性化和定制化開發的,基本上被谷歌給限制死了,這也是現在國產化的意義,希望能夠打破這個限制。不然公司的一些產品和業務不太好開展,總不能用戶提個需求,我們就說谷歌Chrome沒提供API,所我們就無法開發吧。這不是跟客戶扯呢。

          功能的話支持20G文件上傳和續傳,支持秒傳,支持文件夾上傳,支持在服務端保存文件夾層級結構,支持將文件夾層級結構信息保存到數據庫中,支持下載時能夠將文件夾層級結構下載下來,支持下載文件夾,下載文件夾支持斷點續傳,支持VUE2,VUE3,React,支持IE,Chrome和信創國產化環境,比如銀河麒麟,統信UOS,龍芯,支持加密傳輸,包括加密上傳,加密下載,加密算法支持國密SM4,支持云對象存儲,比如華為云,阿里云,騰訊云,七牛云,AWS,MinIO,FastDFS,需要提供手機,QQ,微信,郵箱等聯系方式,提供7*24小時技術支持,提供長期技術支持和維護服務,提供遠程1對1技術指導,提供二次開發指導,提供文檔教程,提供視頻教程。1.下載示例

          https://gitee.com/xproer/up6-vue-cli



          將up6組件復制到項目中

          示例中已經包含此目錄



          1.引入up6組件



          2.配置接口地址

          接口地址分別對應:文件初始化,文件數據上傳,文件進度,文件上傳完畢,文件刪除,文件夾初始化,文件夾刪除,文件列表

          參考:http://www.ncmem.com/doc/view.aspx?id=e1f49f3e1d4742e19135e00bd41fa3de



          3.處理事件



          啟動測試



          啟動成功



          效果



          數據庫



          源碼工程文檔:https://drive.weixin.qq.com/s?k=ACoAYgezAAw1dWofra

          源碼報價單:https://drive.weixin.qq.com/s?k=ACoAYgezAAwoiul8gl

          OEM版報價單:https://drive.weixin.qq.com/s?k=ACoAYgezAAwuzp4W0a

          控件源碼下載:https://drive.weixin.qq.com/s?k=ACoAYgezAAwbdKCskc


          主站蜘蛛池模板: 亚洲一区免费视频| 极品少妇一区二区三区四区| 午夜影视日本亚洲欧洲精品一区 | 中文字幕一区日韩精品| 国产精品va无码一区二区| 在线电影一区二区三区| 久久久精品人妻一区二区三区四| 一区二区视频在线免费观看| 国产99精品一区二区三区免费| 国产精品毛片VA一区二区三区| 久久久久人妻一区二区三区| 三上悠亚一区二区观看| 久久国产视频一区| 一区二区三区四区在线视频| 国模视频一区二区| 国产一区二区三区小说| 国产精品电影一区| 无码精品前田一区二区| 中文字幕在线观看一区二区三区| 国产福利电影一区二区三区| 亚洲中文字幕无码一区二区三区 | 国产福利酱国产一区二区| 一区二区三区在线播放| 亚洲AV综合色一区二区三区| 波多野结衣电影区一区二区三区| 末成年女AV片一区二区| 亚洲色欲一区二区三区在线观看| 免费无码一区二区三区蜜桃大| 亚洲日韩国产一区二区三区在线| 久久国产精品视频一区| 国产精品自拍一区| 人妻精品无码一区二区三区| 日本香蕉一区二区三区| 国模一区二区三区| 国产亚洲欧洲Aⅴ综合一区| 亚洲一区中文字幕在线观看| 国产vr一区二区在线观看| 国产福利91精品一区二区三区| 国产成人一区二区三区电影网站| 99久久精品国产高清一区二区| 色窝窝免费一区二区三区|