TEdgeBrowser 是由微软公司提供的,需要先安装Edge浏览器或安装Edge的运行包;因为限制(不多说)导致直接使用DelphiXE11的 GetIt功能无法连接服务器,所以只有使用手动的方式来进行安装控件
原文参考Embarcadero官方的文档: Using TEdgeBrowser Component and Changes to the TWebBrowser Component – RAD Studio (embarcadero.com)
步骤一:先确保开发电脑上有Edge浏览器;如果有则掠过此步;如果没有可以安装Edge浏览器或者安装Edge的运行包 运行包下载地址
步骤二:打开Delphi XE11;安装控件 Component->New Component
data:image/s3,"s3://crabby-images/26155/26155a4c7be98eb07e5007d3f79289f210076984" alt=""
data:image/s3,"s3://crabby-images/9d18d/9d18dda8970e11632f5e5a5eadedc61891594682" alt=""
data:image/s3,"s3://crabby-images/73098/7309895b5c55199e25623561d170b897fc42b813" alt=""
data:image/s3,"s3://crabby-images/39363/393639d95cea5ae61b330e5d20c79462ca974c6e" alt=""
data:image/s3,"s3://crabby-images/74ec0/74ec062f952ccd2f6f31aafc2fafa28a12a9ee16" alt=""
data:image/s3,"s3://crabby-images/6e730/6e73018f07b1a02d492b747c417da1beec1d4fda" alt=""
步骤三:保存工程并编译安装;至此TEdgeBrowser控件就安装好了;目前该控件只支持VCL,不支持FMX
下面就开始开发了;新建一个VCL项目,拖入EdgeBrowser
data:image/s3,"s3://crabby-images/5b2bb/5b2bbacd2bd9104c99280820e7cde527ea013633" alt=""
实现代码很简单:在FormShow中调用
edgbrwsr1.Navigate('https://www.baidu.com');
Pascal运行一下,白的;哦,看看上面开头的Embarcadero官方文档;原来是缺少支持库WebView2Loader.dll;
data:image/s3,"s3://crabby-images/5f14a/5f14a91438e13bd44c570213911af30a90ce7d0b" alt=""
需要到微软官网下载,地址 NuGet Gallery | Microsoft.Web.WebView2 1.0.2592.51
data:image/s3,"s3://crabby-images/64bd9/64bd9002299e6fce8a776dff49e49d34276fd74f" alt=""
下载好后 microsoft.web.webview2.1.0.2592.51.nupkg 的后缀名修改为zip; 解压打开,提取\build\native\x86\WebView2Loader.dll 和 \build\native\x64\WebView2Loader.dll;
data:image/s3,"s3://crabby-images/bf5e1/bf5e1a96fe7da93392702de3158b0f1328f7df86" alt=""
根据你开发程序把对应的WebView2Loader.dll放到编译输出路径下即可,我开发的是64位程序,放入从 \build\native\x64\WebView2Loader.dll提取的WebView2Loader.dll库后,运行;
走你~~ 期待的画面出现了
data:image/s3,"s3://crabby-images/2b0e0/2b0e058dbd7e43c0f367c3c961703789ca246575" alt=""
但是点击一下后会在Edge浏览器中打开新的页面,稍微设置一下
//需要在控件的NewWindowRequested事件中,添加如下代码即可防止打开新的页面
procedure TForm3.edgbrwsr1NewWindowRequested(Sender: TCustomEdgeBrowser;
Args: TNewWindowRequestedEventArgs);
var
newWin:TNewWindowRequestedEventArgs;
begin
Args.ArgsInterface.Set_NewWindow((Sender as TEdgeBrowser).DefaultInterface);
end;
Pascal怎么样~ 还不错吧? 更多的功能需要自己添加,浏览器兼容性较好,比自带的TWebBrowser兼容性好得多,祝大家开发顺利~~~
data:image/s3,"s3://crabby-images/adc3a/adc3ad3510663607209f6803bebca173eee2b538" alt=""