获得WebBrowser中的图片数据
生活随笔
收集整理的這篇文章主要介紹了
获得WebBrowser中的图片数据
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
/// <summary>
/// 獲取WebBrowser指定的圖片
/// </summary>
/// <param name="webBrowser">需要獲取圖片的WebBrowser</param>
/// <param name="imgID">指定的圖片的id(優先查找指定id)</param>
/// <param name="imgSrc">指定的圖片的src,支持模糊查詢</param>
/// <param name="imgAlt">指定的圖片的src, 支持模糊查詢</param>
/// <returns></returns>
public static Image GetRegCodePic(ref WebBrowser webBrowser, String imgID, String imgSrc, String imgAlt)
{ HTMLDocument doc = (HTMLDocument)webBrowser.Document.DomDocument; HTMLBody body = (HTMLBody)doc.body; IHTMLControlRange rang = (IHTMLControlRange)body.createControlRange(); IHTMLControlElement img; // 如果沒有圖片的ID,通過Src或Alt中的關鍵字來取 if (imgID.Length == 0) { Int32 ImgNum = GetPicIndex(ref webBrowser, ref imgSrc, ref imgAlt); if (ImgNum == -1) return null; img = (IHTMLControlElement)webBrowser.Document.Images[ImgNum].DomElement; } else img = (IHTMLControlElement)webBrowser.Document.All[imgID].DomElement; rang.add(img); rang.execCommand("Copy", false, null); Image regImg = Clipboard.GetImage(); Clipboard.Clear(); return regImg;
} /// <summary>
/// 獲取WebBrowser指定圖片的索引
/// </summary>
/// <param name="webBrowser">指定的WebBrowser</param>
/// <param name="imgSrc">指定的圖片src,支持模糊查詢</param>
/// <param name="imgAlt">指定的圖片alt,支持模糊查詢</param>
/// <returns></returns>
public static Int32 GetPicIndex(ref WebBrowser webBrowser, ref String imgSrc, ref String imgAlt)
{ IHTMLImgElement img; // 獲取所有的Image元素 for (Int32 i = 0; i < webBrowser.Document.Images.Count; i++) { img = (IHTMLImgElement)webBrowser.Document.Images[i].DomElement; if (imgAlt.Length == 0) { if (img.src.IndexOf(imgSrc) >= 0) return i; } else { if (imgSrc.Length == 0) { // 當imgSrc為空時,只匹配imgAlt if (img.alt.IndexOf(imgAlt) >= 0) return i; } else { // 當imgSrc不為空時,匹配imgAlt和imgSrc任意一個 if (img.alt.IndexOf(imgAlt) >= 0 || img.src.IndexOf(imgSrc) >= 0) return i; } } } return -1;
}
轉載于:https://www.cnblogs.com/XuPengLB/p/8024065.html
總結
以上是生活随笔為你收集整理的获得WebBrowser中的图片数据的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [Spark][Python]sortB
- 下一篇: css背景图宽度只适应,高度不变