整合營銷服務商

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

          免費咨詢熱線:

          .NET程序瀏覽器集成組件DotNetBrowser v2.7上線!引用Chromium 91

          otNetBrowser是一個.NET庫,允許將基于Chromium的WPF和WinForms組件嵌入到.NET應用程序中,以顯示使用HTML5,CSS3,JavaScript,Silverlight等構建的現代網頁。

          DotNetBrowser迎來v2.5版本更新,在此更新中,帶來了更新的 Chromium 引擎和具有新功能的 API,為了方便大家盡可能順利過度新版本,我們特意準備了本指南將幫助您了解新版本都要哪些新增與改動。還沒有使用過可以點擊下方鏈接下載哦~

          DotNetBrowser官方最新版免費下載試用,歷史版本下載,在線文檔和幫助文件下載-慧都網

          新功能

          引用Chromium 91

          Chromium 引擎已更新到版本 91.0.4472.114。

          此 Chromium 版本包含幾個重要的安全修復程序,因此我們建議您升級到此版本。

          結構

          DotNetBrowser API 已使用 Chromium 配置文件進行了擴展。現在,該架構具有以下結構:

          每個引擎都有一個默認值,IProfile您可以通過以下方式訪問:

          IProfile defaultProfile = engine.Profiles.Default;

          要創建新的常規或隱身個人資料,請使用以下 API:

          IProfile profile = engine.Profiles.Create("MyProfile");
          IProfile incognitoProfile = engine.Profiles.Create("MyIncognitoProfile", 
                                                             ProfileType.Incognito);

          每個IBrowser實例都有一個配置文件。要IBrowser為特定配置文件創建實例,請使用以下方法:

          IProfile profile = engine.Profiles.Create("MyProfile");
          IBrowser browser = profile.CreateBrowser();

          為了向后兼容,我們沒有改變IEngine界面。它只是將其調用委托給默認配置文件。例如:

          IBrowser browser = engine.CreateBrowser();
          // is equivalent of
          IBrowser browser = engine.Profiles.Default.CreateBrowser();
          ICookieStore cookieStore = engine.CookieStore;
          // is equivalent of
          ICookieStore cookieStore = engine.Profiles.Default.CookieStore;

          如果您IEngine使用用戶數據目錄配置 ,則所有創建的配置文件將在應用程序重新啟動后恢復。

          查看頁面源代碼

          現在您可以像在谷歌瀏覽器中一樣查看加載的網頁或框架的來源:

          browser.MainFrame?.ViewSource();

          上面的代碼告訴 Chromium 創建并打開一個帶有主框架的 HTML 源代碼的彈出窗口。它將是一個具有以下外觀的常規彈出窗口:

          可以通過瀏覽器設置強制首選配色方案:

          browser.Settings.PreferredColorScheme = PreferredColorScheme.Dark; //forces dark mode
          browser.Settings.PreferredColorScheme = PreferredColorScheme.Light; //forces light mode

          默認背景色

          當 Chromium 不知道網頁的背景顏色,或者根本沒有指定顏色時,它使用白色。在此版本中,我們使用新功能擴展了 API,允許您配置 Chromium 應使用的默認背景顏色,而不是這種情況下的默認白色。

          以下代碼演示了如何為 about:blank 頁面設置所需的背景顏色:

          Color purple = new Color(0.6f, 0.3f, 0.6f);
          browser.Settings.DefaultBackgroundColor = purple;

          畫中畫

          現在可以在與其他網站或應用程序交互時在浮動窗口(在其他窗口之上)觀看視頻。

          改進

          • 現在可以通過IJsPromise類型使用 JavaScript 承諾。
          • IFrame.Text屬性已添加。它允許以純文本形式獲取框架的內容。
          • WPF 應用程序中 WinForms BrowserView 控件的焦點行為已得到改進。
          • 導航到不同域時,SetWindowDisplayAffinity()與WDA_MONITOR參數一起使用的WinAPI 函數不再導致 Chromium 崩潰。

          , 兼容性是什么?

          同樣的HTML+CSS+JS,但是表現出的外部特征還是不能達到統一,存在瑕疵。同樣的代碼,有的瀏覽器效果顯示"正常",有的顯示"不正常"。就像同樣的去吃大排檔,就有的人吃完一點事沒有,而有的人就會拉肚子。

          2,為什么瀏覽器會存在兼容問題?

          不同廠家開發所用的核心架構不同和代碼很難重合,實現方式也有差異,所以呈現在頁面上的樣式也就會有一部分的差異,看著會有些不同。

          3,處理兼容問題的思路:

          1):要不要去做?(看做的產品的影響程度,受眾面,是主打效果還是基本功能)

          2):做到什么程度?(想要那些瀏覽器支持,就給那些瀏覽器做兼容)

          3):怎么做?(根據兼容問題,來選擇那些框架,和那些兼容工具。)

          4,漸進增強和優雅降級

          1):漸進增強:現針對低版本瀏覽器進行基本功能和頁面,再針對高版本的瀏覽器進行效果,交互,和用戶體驗做出改進。

          2):優雅降級:一開始就先針對于高版本瀏覽器進行完整的頁面展示(效果,交互,功能,用戶體驗),然后在對低版本瀏覽器進行兼容

          5,常見的兼容問題

          1,高度塌陷

          浮動元素的父元素自適應(父元素不寫高度時,子元素寫了浮動后),父元素會發生高度塌陷

          解決方案

          1) :給父元素添加聲明:overflow:hidden;

          2) :字啊浮動元素下方添加空div。并給該元素聲明,clera:both;height:0;overflow:hidden;

          2, 最小高度自適應(因為min-heigh本身就是一個不兼容的css屬性,所以各個瀏覽器不兼容

          1) :min-height:value;-height:value

          2) :min-height:value;heigth:auto!Important;height:value

          3,按鈕元素大小不一樣

          1) :給按鈕統一大小

          2) :外邊套一個標簽,在標簽與按鈕樣式把input邊框和背景去掉

          4,圖片默認有間距(幾個img標簽放在一起的時候,有些瀏覽器會有默認的間距

          1);給img添加float屬性

          5,ie6圖片下方會產生間隙

          1):為圖片設置display;block;

          6,ie8以下的透明

          1):filler:alpha(取值范圍0-100)例如:filter:alpha(opacity=60)

          7,空div的默認行高(清浮動時會使用一個空的div,在大部分瀏覽器沒問題,在ie6中即使div是空的也會有默認行高

          1)設置其高度為0,并設置overflow:hidden。

          6,一些兼容性相關的工具和庫

          1):用于解決IE9以下版本瀏覽器對HTML5新增標簽不識別,并導致CSS不起作用的問題。

          2):Respond.js:是一個快速、輕量的 polyfill,用于為 IE6-8 以及其它不支持 CSS3 Media Queries 的瀏覽器提供媒體查詢的 min-width 和 max-width 特性,實現響應式網頁設計

          3):CSS Reset:重置瀏覽器的css默認屬性;瀏覽器的品種不一樣,那么對默認樣式的解釋不一樣,通過reset可以達到顯示一致的效果。

          4):normalize.css:是一個可以定制的CSS文件,它讓不同的瀏覽器在渲染網頁元素的時候形式更統一。

          5)Modernizr.js:傳統瀏覽器目前不會被完全取代,令你難以將最新的 CSS3 或 HTML5 功能嵌入你的網站。 Modernizr 正是為解決這一難題應運而生,它也可以通過加載定制的腳本來模擬老版本瀏覽器不支持的功能。

          篇文章主要介紹了HTML5實現音頻和視頻嵌入的方法的相關資料,原生的支持音頻和視頻,為HTML5注入了巨大的發展潛力,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

          簡介

          HTML5未出來之前,在線的音頻和視頻都是借助Flash或者第三方工具實現的,現在HTML5也支持了這方面的功能。在一個支持HTML5的瀏覽器中,不需要安裝任何插件就能播放音頻和視頻。原生的支持音頻和視頻,為HTML5注入了巨大的發展潛力。

          html實現音頻嵌入(傳統方式):這種方式雖然可以實現,但是要瀏覽器支持Flash而且并不能實現控制,所以要實現起來很麻煩。

          <object height="200" width="200" data="2_1.swf" >

          </object>

          <embed src="2_1.mp4" type="">

          那么也就是說HTML5存在一個很大的問題就是兼容性。音頻

          HTML5支持的音頻格式:



          視頻

          視頻格式:



          由上可知,HTML5貌似支持的格式有點少哈,所以當你發現用HTML5放置音頻和視頻不顯示時,應該就是格式不支持的問題。注: MP4有3種編碼,mpg4(xdiv),,mpg4(xvid),avc(h264), 只有h264才是公認的MP4標準編碼(在這也是被坑了,其他格式的只有聲音沒有圖像。)遇到這種問題,就用視頻格式轉換器,轉換一下格式就OK啦。

          音頻實現起來很簡單:這里工具條使用了瀏覽器默認的工具條。

          ?

          1

          2

          3

          <audio src="htmls/1.mp3" controls="controls" loop="loop" preload="auto" >

          你的瀏覽器不支持video元素

          </audio>



          視頻雖然也可以使用瀏覽器默認的,但無法實現私人訂制,所以從學技術的角度講,還是要學習一下自己做工具實現功能(audio也可參照此方法)。

          audioVideo.html

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="UTF-8">

          <title>網頁放置視頻</title>

          <style type="text/css">

          </style>

          <script type="text/javascript" src="js/ControlBar.js"></script>

          </head>

          <body>

          <audio src="htmls/1.mp3" controls="controls" loop="loop" preload="auto" >

          你的瀏覽器不支持video元素

          </audio>

          <video id="myPlayer" width="600" height="400" src="htmls/2_1.mp4" controls="controls" loop="loop" poster="3.jpg">

          你的瀏覽器不支持audio元素

          <!-- MP4有3種編碼,mpg4(xdiv),,mpg4(xvid),avc(h264),

          只有h264才是公認的MP4標準編碼 -->

          </video>

          <div id="progress"></div>

          <!-- 音量控制 -->

          <input id="volume" type="range" min="0" max="1" step="0.1" onchange="Volume(this)">

          <!-- 速率和時間進度的信息 -->

          <span id="rate">1</span>fps <span id="info"></span>

          <button onclick="Play(this)" id="btn1">播放</button>

          <button onclick="Fast()">快進</button>

          <button onclick="Slow()">慢進</button>

          <button onclick="Prev()">后退</button>

          <button onclick="Next()">前進</button>

          <button onclick="Muted(this)">靜音</button>

          </body>

          </html>

          顯示(html)與功能實現(js)分離,由外部導入

          ControlBar.js

          //使用腳本檢測瀏覽器的標簽支持情況

          var support = !!document.createElement("audio").canPlayType;

          if (!support) {

          alert("你的瀏覽器不支持本視頻播放");

          }

          // 定義全局的視頻對象

          var e1 = null;

          window.addEventListener("load", function() {

          e1 = document.getElementById("myPlayer");

          });

          /*前進:一分鐘 */

          function Next() {

          e1.currentTime+=10; //設置屬性currentTime,快進10s

          }

          /*后退:一分鐘 */

          function Prev() {

          e1.currentTime-=10; //設置屬性currentTime,后退10s

          }

          /*播放/暫停*/

          function Play(e) {

          if(e1.paused){

          e1.play();

          document.getElementById("btn1").innerHTML="暫停"

          }else{

          e1.pause();

          document.getElementById("btn1").innerHTML="播放"

          }

          }

          /*慢進:小于等于1時,每次都只減慢0.2的速率;大于1時,每次減1 */

          function Slow(){

          if(e1.playbackRate<=1){

          e1.playbackRate-=0.2;

          }else{

          e1.playbackRate-=1;

          }

          document.getElementById("rate").innerHTML=fps2fps(e1.playbackRate);

          }

          /*慢進:小于等于1時,每次都只減慢0.2的速率;大于1時,每次減1 */

          function Fast(){

          if(e1.playbackRate<1){

          e1.playbackRate+=0.2;

          }else{

          e1.playbackRate+=1;

          }

          document.getElementById("rate").innerHTML=fps2fps(e1.playbackRate);

          }

          function fps2fps(fps){

          if(fps<1){

          return fps.toFixed(1);

          }else{

          return fps;

          }

          }

          /*靜音*/

          function Muted(e){

          if(e1.muted){

          e1.muted=false;

          e.innerHRML="X";

          document.getElementById("volume").value=e1.volume;

          }else{

          e1.muted=true;

          e.innerHRML="x";

          document.getElementById("volume").value=0;

          }

          }

          /*調整音量*/

          function Volume(e){

          if(e1.muted==true){

          e1.muted=false;

          }

          e1.volume=e.value;

          }

          /* 進度信息:控制進度條,并顯示進度時間*/

          function Progress(){

          var p1=document.getElementById("progress");

          p1.style.width=(e1.currentTime/e1.duration)*720+"px";

          document.getElementById("info").innerHTML=s2time(e1.currentTime)+"/"+s2time(e1.duration);

          }

          function s2time(s){

          var m=parseFloat(s/60).toFixed(0);

          s=parseFloat(s%60).toFixed(0);

          return (m<10? "0"+m:m)+":"+(s<10?"0"+s:s);

          }

          /* 網頁加載完畢后,把進度處理函數添加至視頻對象的timeupdate事件中*/

          window.addEventListener("load",function(){

          e1.addEventListener("timeupdate",Progress);

          });

          /*給window.onload事件添加進度處理函數*/

          window.addEventListener("load",Progress);

          實現的功能:播放,暫停,快進,慢進,前進,后退,音量控制,進度條和時間顯示。由此可見通過Audio或Video的屬性和方法可以實現更復雜的功能。


          主站蜘蛛池模板: 精品久久久久久无码中文字幕一区| 麻豆天美国产一区在线播放| 国产福利精品一区二区| 91精品福利一区二区三区野战| 中文字幕一区一区三区| 亚洲美女高清一区二区三区| 波霸影院一区二区| 日本不卡一区二区三区视频| 中文字幕一区二区三区乱码| 日本亚洲国产一区二区三区| 国产亚洲综合精品一区二区三区| 精品人妻无码一区二区色欲产成人 | 少妇无码一区二区二三区| 久久精品国产一区二区三区不卡| 日本激情一区二区三区| 午夜福利一区二区三区高清视频| 久久精品日韩一区国产二区| 麻豆一区二区在我观看| 久久精品免费一区二区| 精品无码人妻一区二区免费蜜桃 | 精品少妇人妻AV一区二区 | 亚洲视频一区调教| 亚洲AV无码一区二区三区在线观看| 亚洲国产精品一区| 色偷偷一区二区无码视频| 一区高清大胆人体| 日韩精品久久一区二区三区| 狠狠综合久久av一区二区| 国产精品va一区二区三区| 无码日韩人妻AV一区免费l | 视频一区二区中文字幕| 久久久不卡国产精品一区二区| 国产色综合一区二区三区| 精品久久综合一区二区| 色狠狠一区二区三区香蕉蜜桃| 免费无码VA一区二区三区| 日本人真淫视频一区二区三区| 国产高清在线精品一区二区三区| 亚洲国产精品无码久久一区二区 | 亚洲AV无码一区东京热| 久久se精品一区精品二区|