C# 依据鼠标坐标取网页内成员坐标.ie
C# 根据鼠标坐标取网页内成员坐标.ie
有时候你需要后台获取ie浏览器 鼠标所在位置的元素坐标,然而你使用屏幕坐标是不可行的
所以我们需要把坐标转换成浏览器内坐标 然后再通过elementFromPoint获取网页成员。
private void tmrWatcher_Tick(object sender, EventArgs e)
{
IntPtr hWnd = WindowFromPoint(MousePosition);
dynamic document = GetHtmlDocumentByHandle(hWnd);
if (document != null)
{
Rectangle r = GetHtmlElementPoint(hWnd, MousePosition, document); // 根据鼠标坐标取网页成员坐标
Marshal.FinalReleaseComObject(document);
Console.WriteLine(r.X + ":" + r.Y + ":" + r.Width + ":" + r.Height);
}
}
上面是一个时钟tmrWatcher的Tick回调函数,在上面使用了WindowFromPoint函数 主要是获取
MousePosition所在的窗口句柄,然后再通过GetHtmlDocumentByHandle函数(获取文档从句柄)
public static object GetComObjectByHandle(int Msg, Guid riid, IntPtr hWnd)
{
object _ComObject;
int lpdwResult = 0;
if (!SendMessageTimeout(hWnd, Msg, 0, 0, SMTO_ABORTIFHUNG, 1000, ref lpdwResult))
return null;
if (ObjectFromLresult(lpdwResult, ref riid, 0, out _ComObject))
return null;
return _ComObject;
} public object GetHtmlDocumentByHandle(IntPtr hWnd)
{
string buffer = new string('\0', 24);
GetClassName(hWnd, ref buffer, 25);
if (buffer != "Internet Explorer_Server")
return null;
return GetComObjectByHandle(WM_HTML_GETOBJECT, IID_IHTMLDocument, hWnd);
}
实际上与我上次的帖子:http://blog.csdn.net/u012395622/article/details/46404193
并没什么太大的出入,而获取一个网页文档的成员只是简单的调度Mshtml COM接口
public Rectangle GetHtmlElementPoint(IntPtr hWnd, Point point, dynamic document)
{
if (document == null && hWnd != IntPtr.Zero)
return Rectangle.Empty;
ScreenToClient(hWnd, ref point);
dynamic element = document.elementFromPoint(point.X, point.Y);
if (element == null) return Rectangle.Empty;
try
{
Rectangle o = new Rectangle()
{
Y = element.offsetTop,
X = element.offsetLeft,
Width = element.offsetWidth,
Height = element.offsetHeight
};
while (element.offsetParent != null)
{
element = element.offsetParent;
o.Y += element.offsetTop;
o.X += element.offsetLeft;
}
return o;
}
catch
{
return Rectangle.Empty;
}
}
上面代码是实现获取 元素在网页内的一个确切坐标,整体并不是很难阅读的。
之所以while(element.offsetParent != null) { ... }是因为网页始终与客户端不相
同我们不能用常规在Win32操作控件位置那样去看待它 它很麻烦,而且层次
很难分明,所以会造成你根本不知道到底有多宽不过还好,一般计算一个
成员元素在窗口什么位置,只要把父容器的位置加起来就行了。反正有点
解释的不清楚,大家莫见怪
[DllImport("user32.dll", CharSet = CharSet.Auto, ExactSpelling = true)]
public static extern bool ScreenToClient(IntPtr hWnd, ref Point lpPoint); [DllImport("user32.dll", SetLastError = true)]
[return: MarshalAs(UnmanagedType.Bool)]
public static extern bool GetClassName(
[In]IntPtr hWnd,
[MarshalAs(UnmanagedType.VBByRefStr)]ref string IpClassName,
[In]int nMaxCount
); [DllImport("oleacc.dll", SetLastError = true)]
[return: MarshalAs(UnmanagedType.Bool)]
public static extern bool ObjectFromLresult(
[In]int lResult,
[In]ref Guid riid,
[In]int wParam,
[Out, MarshalAs(UnmanagedType.IUnknown)]out object ppvObject
); [DllImport("user32.dll", SetLastError = true)]
[return: MarshalAs(UnmanagedType.I4)]
public static extern int RegisterWindowMessage(
[In]string lpString
); [DllImport("user32.dll", EntryPoint = "SendMessageTimeoutA", SetLastError = true)]
[return: MarshalAs(UnmanagedType.Bool)]
public static extern bool SendMessageTimeout(
[In]IntPtr MSG,
[In]int hWnd,
[In]int wParam,
[In]int lParam,
[In]int fuFlags,
[In]int uTimeout,
[In, Out]ref int lpdwResult
); [DllImport("user32.dll", SetLastError = true)]
[return: MarshalAs(UnmanagedType.SysInt)]
public static extern IntPtr WindowFromPoint(
[In]Point Point
); public const int SMTO_ABORTIFHUNG = 2; public readonly static int WM_HTML_GETOBJECT = RegisterWindowMessage("WM_HTML_GETOBJECT");
public readonly static Guid IID_IHTMLDocument = new Guid("626fc520-a41e-11cf-a731-00a0c9082637");
C# 依据鼠标坐标取网页内成员坐标.ie的更多相关文章
- Python3爬虫----爬取网页内的图片
无聊把公司内网爬了一遍. https://github.com/gig886/Python/tree/master/爬虫
- python 爬取网页内的代理服务器列表(需调整优化)
#!/usr/bin/env python # -*- coding: utf-8 -*- # @Date : 2017-08-30 20:38:23 # @Author : EnderZhou (z ...
- 利用Python爬取网页图片
最近几天,研究了一下一直很好奇的爬虫算法.这里写一下最近几天的点点心得.下面进入正文: 你可能需要的工作环境: Python 3.6官网下载 我们这里以sogou作为爬取的对象. 首先我们进入搜狗图片 ...
- [转载]爬虫的自我解剖(抓取网页HtmlUnit)
网络爬虫第一个要面临的问题,就是如何抓取网页,抓取其实很容易,没你想的那么复杂,一个开源HtmlUnit包,4行代码就OK啦,例子如下: 1 2 3 4 final WebClient webClie ...
- [python] 常用正则表达式爬取网页信息及分析HTML标签总结【转】
[python] 常用正则表达式爬取网页信息及分析HTML标签总结 转http://blog.csdn.net/Eastmount/article/details/51082253 标签: pytho ...
- HTML-图片热点、网页内嵌、网页拼接、快速切图
图片热点 规划出图片上的一个区域,可以做出超链接,直接点击图片区域就可以完成跳转的效果.与图片链接不同,热点是图片上的某一个区域或多个区域. 我们用魔兽世界图片来做一个图片热点,点击logo.区域和不 ...
- 爬虫的自我解剖(抓取网页HtmlUnit)
网络爬虫第一个要面临的问题,就是如何抓取网页,抓取其实很容易,没你想的那么复杂,一个开源`HtmlUnit`包,4行代码就OK啦,例子如下: final WebClient webClient=new ...
- python分布式抓取网页
呵呵,前两节好像和python没多大关系..这节完全是贴代码, 这是我第一次写python,很多地方比较乱,主要就看看逻辑流程吧. 对于编码格式确实搞得我头大..取下来页面不知道是什么编码,所以先找c ...
- HTML5绘制矩形和圆形并且还有获取在这个图层内的坐标的思路和代码 - feilong_12的专栏 - 博客频道 - CSDN.NET
body{ font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI& ...
随机推荐
- 用jsp实现网站登录界面的制作,并连接数据库
课堂测试 任务需求: 撰写一篇博客 需要网站系统开发需要掌握的技术: 本次课堂测试的源程序代码: 运行结果截图: 说明课堂测试未按时完成的原因. 列出你对这门课的希望和自己的目标,并具体列出你计划每周 ...
- C#模拟HTTP POST 请求
GET请求: /// <summary> /// 获取accessToken /// </summary> /// <param name="corpid&qu ...
- Python logger模块
1 logging模块简介 logging模块是Python内置的标准模块,主要用于输出运行日志,可以设置输出日志的等级.日志保存路径.日志文件回滚等:相比print,具备如下优点: 可以通过设置不同 ...
- Linux案例01:eth0网卡异常
一.现象描述 今天在调试两台物理机,做完配置重启主机后,发现一台服务器网络无法ssh连接,通过ILO进去ifconfig发现eth0配置的IP地址等信息丢失,手动重启后,可以ssh连接,但过一段时间, ...
- Facebook POP 使用指南
Facebook POP 使用指南 Pop是一个动画引擎,用以扩展iOS.OSX的动画类型.相较于iOS.OSX中的基本动画效果,Pop扩展后支持弹簧动画效果与衰减动画效果,你可以用Pop动画引擎来构 ...
- Mysql学习---索引的学习 180101
索引:约束 + 快速查找 索引是数据库中用于帮助用户快速查询数据的一种数据结构.类似于字典中的目录,查找字典内容时可以根据目录查找到数据的存放位置,然后直接获取即可. 问:为什么索引可以这么快?[类似 ...
- 编程语言——C----细节
2017-09-27 18:40:47 程序设计的基本概念 1.计算机语言:把人与计算机之间交流的语言叫做计算机语言 1)计算机语言分为高级语言和低级语言 2)高级语言:远离硬件 3)低级语言:贴近 ...
- webbench 网站压力测试
[root@localhost ~]# webbench -c 500 -t 4 http://172.24.61.41/Webbench - Simple Web Benchmark 1.5Copy ...
- unittest:1 用例编写
unittest是python自带的单元测试框架,包含测试用例case,测试集suite,测试集加载loader,测试执行runner,测试结果result等. 简单使用:写一个用例类继承自unitt ...
- POI读取单元格信息及单元格公式
Java操作EXCEL的利器一般都是POI和JXL,鄙人只是POI的忠实粉丝.(其实我是没有用过JXL). 现在大多数的excel都是07以上的版本,所以我一般是用07的基础上使用POI. 一.读取单 ...