锚点标记

不知道有没有人研究过这个,当点击页面的锚点连接的时候一般就跳转到特定id的元素,而实际表现的是滚动条滚动使该特定id元素对齐滚动条所处元素 的顶端。

那假如我现在要求这个位置不是在顶端,而是离顶端有一定距离。

先看看我实现的方法例子:


[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]

这实际上是一种掩眼法,对齐的参考点还是在元素的顶端,只是我把元素的设置了特定的border-top(padding-top也可 以,margin-top不可以),锚点就可以好像真的一样偏移到目标标题文字,但是这样会使下来元素之间产生一段距离,那么我们只要设置其 margin-top为负值,而且刚好为padding-top的值即可。但是还会产生一个问题,margin-top为负数值时,会强行把元素的 padding-top覆盖到上一元素上面(假如你没有设置背景色是很难看出来的),那怎么办呢?很自然我们就会想到z-index的方法,单纯设置z- index没有用,要先设置其positon为relative,这样就可以了。(注意:这里假如h2设置的padding-top值超过了p的高度[包 括border和padding]值会引起层叠问题,解决方法是一样的。)

实例css代码:

/*初始化,使不影响判断*/


body, h2, p{ margin : 0;padding: 0;}
/*因为要设置z-index需要先设置一下position*/
h2, p{ width : 500px ;position: relative ;}
p{ height : 400px ;background: #CCC ;z-index: 2 ;}
p.extra{
margin : 0 0 500px ;/*最后一个p需要有一定的底端margin不然滚动条不够高度,会使达不到最后一个标题*/
}
h2{
margin : -200px 0 0;/*强行把元素位置拉回原位*/
border-top : 200px solid #000 ;/*改变目标元素对于锚点的基点位置,这里可以用padding-top,但是有不一样的问题出现,都可以很简单解决,这里不详说了*/
z-index : 1 ;
background : #06F ;
}
#anchor1 {
margin : 0;/*第一个元素不应该被拉回原位*/
}
span{ position : fixed !important; position : absolute ;top: 200px ;left: 510px ;}
#menu { background : #CCC ; position : fixed !important; position : absolute ;left: 510px ; top : 2px ; }

有人可能会问为什么要这么麻烦?在这些元素的外面加一个父元素,然后把父元素移位不就成了么?这个确实是一个办法,但是假如你考虑到滚动条,你就会 发现一个很难解决的问题,这里我就不介绍了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
锚点辅助定位是一种在图像或视频中利用特定的标记或特征进行定位的技术。在Matlab中,可以使用计算机视觉工具箱来实现伪锚点辅助定位操作。 首先,加载图像或视频数据: ```matlab image = imread('image.jpg'); % 读取图像文件 % 或者 video = VideoReader('video.mp4'); % 读取视频文件 ``` 接下来,通过图像或视频的任意帧提取伪锚点标记的位置信息。可以使用计算机视觉工具箱中的特征检测、角检测或者模板匹配等技术来定位伪锚点。 ```matlab points = detectSURFFeatures(image); % 提取SURF特征 % 或者 points = detectHarrisFeatures(image); % 提取Harris角 % 或者 template = imread('template.png'); % 读取模板图片 corr = normxcorr2(template, image); % 模板匹配 [y, x] = find(corr == max(corr(:))); % 找到匹配最好的位置 ``` 然后,根据伪锚点位置进行辅助定位。通过计算伪锚点的位置与目标位置之间的位置关系,可以实现目标的定位。 ```matlab targetPoint = [100, 200]; % 目标位置 % 计算伪锚点与目标的偏移量 offset = targetPoint - points.Location; % 或者 offset = targetPoint - [x, y]; % 定位目标 targetLocation = targetPoint + offset; ``` 最后,根据需求可进一步处理定位结果,例如绘制伪锚点和目标位置等。 ```matlab imshow(image); hold on; plot(points); plot(targetLocation(1), targetLocation(2), 'r*'); % 绘制定位结果 hold off; ``` 以上就是使用Matlab代码实现伪锚点辅助定位的简单示例。具体的实现方式可以根据实际需求进行选择和修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值