iPhone X刘海列表环绕交互 -- shape-outside:url("图片")

看到旭神博客上的一篇文章,关于iPhone X刘海发型设计和衍生的交互,其就是通过CSS3 Shapes实现元素滚动自动环绕iPhone X头部刘海效果。这里我整理了一下,写一个缩减版。

iPhone X的刘海发型和衍生的交互

首先先看一下微博上流传的交互样式。

iPhoneX刘海衍生的交互

可以看出此交互就是滚动页面时,列表会环绕着iPhoneX的刘海排列。
实际上,CSS3里面针对这种特定形状环绕的效果已经支持很久了,CSS3 Shapes和CSS3 Regions都是可以实现的,只是我们接触甚少。

CSS Shapes环绕iPhone X刘海简易方法

这里就描述一种在技术上简单易懂的解决方式。

实现原理

CSS Shapes中有个CSS属性名为shape-outside,可以让内联元素以不规则的形状进行外部排列,语法如下:

/* 函数值 */
shape-outside: circle();
shape-outside: ellipse();
shape-outside: inset(10px 10px 10px 10px);
shape-outside: polygon(10px 10px, 20px 20px, 30px 30px);

/* <url>值 */
shape-outside: url(image.png);

/* 渐变值 */
shape-outside: linear-gradient(45deg, rgba(255, 255, 255, 0) 150px, red 150px);

shape-outside属性想要生效,本身需要是浮动float元素。
本demo效果实现的简易方法就是使用shape-outside:url('image.png')属性实现类似效果,image.png就是用来被环绕的图片,相当于iPhoneX的刘海设计,环绕与否是基于计算alpha通道决定,简单来讲,就是沿着图片非透明区域环绕。
由于使用url()的形状计算是基于图片元素,和Shapes其他四个inset(),circle(),ellipsepolygon()这些基础形状方法的计算性质不一样,可以直接使用垂直方向的margin进行偏移。
先来看下实现效果吧

shape-outside url实现效果
细节说明

列表环绕的刘海图片和实际在页面显示的刘海图并非是一张图片,为了让刘海和列表文字之间留有空隙,要将url('liu-outside.png')中的 liu-outside.png图片做实色填充处理,这里是填充了6像素。

代码:

css代码

*{
    margin: 0;
    padding: 0;
    list-style: none;
 }
.box{
    max-width: 600px;
    height: 380px;
    border: 4px solid #000;
    overflow: auto;
    margin: auto;
 }
.liuOutside{
    float: left;
    width: 30px;
    height: 180px;
    margin-top: 100px;
    -webkit-shape-outside: url('./liu-outside.png'); 
    shape-outside: url('./liu-outside.png');
    transition: margin-top .15s;
 }
.liuhai{
    width: 24px;
    height: 180px;
    background: url("./liu.png") no-repeat left center;
    margin-top: 100px;
    position: absolute;
 }
.scrollContent li{
    border-bottom: 1px solid #ddd;
    padding: 1em;
}

html代码

    <div class="box">
        <i class="liuOutside"></i>
        <i class="liuhai"></i>
        <ul class="scrollContent">
            <li>这个方法是比较简单的</li>
            <li>使用shape-outside url(image.png)语法</li>
            <li>其中'image.png'就是用来被环绕的图片</li>
            <li>环绕与否是基于计算alpha通道决定</li>
            <li>即沿着图片非透明区域环绕</li>
            <li>为了不至于列表靠的太近</li>
            <li>shape的url图片右侧</li>
            <li>刻意填充了6像素实色</li>
            <li>现在看到的齐刘海</li>
            <li>是覆盖在上面的一张图</li>
            <li>实际生效的是后面浮动的shape</li>
            <li>此功能的实现需要JS的配合</li>
            <li>主要控制margin-top值</li>
            <li>只能对内联信息进行跟随控制</li>
        </ul>
    </div>

js代码

var liuOutside = document.querySelector(".liuOutside");
var box = document.querySelector(".box");
var outside = function() {
    var scrollTop = box.scrollTop;
    // 滚动偏移应用在margin-top上
    liuOutside.style.marginTop = (100 + scrollTop) + "px";
};
// 滚动时实时监听改变shape的形状
box.addEventListener("scroll",outside);
outside();
Tips

1.效果的实现必须要js代码的配合,否则会出现很难受的效果,如下:

未有js代码实现效果

2.还有一种实现方案就是shape-outside:polygon(),通过点坐标勾勒出和齐刘海形状相似的多边形形状,css代码如下:

.liuOutside{
    float: left;
    shape-outside: polygon(0 0, 0 100px, 16px 104px, 30px 116px, 30px 264px, 16px 276px, 0 280px, 0 0);
}

应该想到的是,既然方法换了,那么js代码相应的也需要作出改变:

box.addEventListener('scroll', function () {
    var scrollTop = box.scrollTop;
    // 滚动偏移应用在shape-outside上
    shape.style.shapeOutside = 'polygon(0 0, 0 '+ (100 + scrollTop) +'px, 16px '+ (104 + scrollTop) +'px, 30px '+ (116 + scrollTop) +'px, 30px '+ (264 + scrollTop) +'px, 16px '+ (276 + scrollTop) +'px, 0 '+ (280 + scrollTop) +'px, 0 0)';
});

此方法在确定环绕点时比较繁琐。
3.附上用到的两张刘海图片

注:根据张鑫旭大牛的文章所写,一起学习。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容

  • iPhone X造型上有个显著的特质,就是有个明显的刘海。然后,也出现了一些酷酷的交互。体验 CSS3 Shape...
    你期待的花开阅读 432评论 1 2
  • CSS代码: .box{max-width:414px;height:480px;border:solid#000...
    指尖的跳动阅读 465评论 0 0
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,728评论 1 92
  • 即使是多年未见,我们的情谊也还是长存 蛮羡慕老爸和他的同学们的感情的。就算那么多年没见,也还是没有一点隔阂。 他们...
    阳妹儿阅读 386评论 0 0
  • 尽头之处:悲伤堵塞悲伤,孤独凝结孤独, 痛苦化开痛苦! ​​​ 尽头之处:快乐,是一种崩溃 雪花,是一种放下 腐烂...
    鲸香阅读 450评论 0 0