六边形的边缘在铬中不显示光滑

时间:2015-07-13 12:07:42

标签: javascript jquery html css google-chrome

我在Chrome中遇到了一个问题我创建了一个包含HTMLCSS的六边形组。它在firefox中显示得很好,但在chrome中六边形的边缘显示扭曲。我的代码如下

HTML

<div class="col-sm-12 margin-left-100" id="sortable">
    <div id="c_1" class="hexagon hexagon2 sort">
    <div class="hexagon-in1">
        <div class="hexagon-in2">
            <div class="inner inner-left text-center"><i class="fa fa-eye"></i></div><div class="inner inner-right text-center"><i class="fa fa-link"></i></div>
        </div>
    </div>
</div>
<div id="c_2"  class="hexagon hexagon2 sort">
    <div class="hexagon-in1">
        <div class="hexagon-in2">
            <div class="inner inner-left text-center"><i class="fa fa-eye"></i></div><div class="inner inner-right text-center"><i class="fa fa-link"></i></div>
        </div>
    </div>
</div>
</div>

CSS

.hexagon {
    overflow: hidden;
    visibility: hidden;
    -webkit-transform: rotate(120deg);
    -moz-transform: rotate(120deg);
    -ms-transform: rotate(120deg);
    -o-transform: rotate(120deg);
    transform: rotate(120deg);
    cursor: pointer;
    }
.hexagon-in1 {
    overflow: hidden;
    width: 100%;
    height: 100%;
    -webkit-transform: rotate(-60deg);
    -moz-transform: rotate(-60deg);
    -ms-transform: rotate(-60deg);
    -o-transform: rotate(-60deg);
    transform: rotate(-60deg);
    }
 .hexagon-in2 {
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: 50%;
    visibility: visible;
    -webkit-transform: rotate(-60deg);
    -moz-transform: rotate(-60deg);
    -ms-transform: rotate(-60deg);
    -o-transform: rotate(-60deg);
    transform: rotate(-60deg);
    }
.hexagon-in2{
    background: #6B6A6A;
    }

.hexagon1 {
    width: 200px;
    height: 100px;
    margin: 0 0 0 -80px;
    }
.hexagon2 {
   float: left;
   width: 80px;
   height: 117px;
   margin: -20px 0 0 20px;
  }
.inner{position: relative;color: #FFF; display: none; padding-top: 6px;   background: #009999;width: 50px;width: 34px;height: 32px;border-radius: 25px;}
div#sortable .hexagon:nth-child(5) {
    margin-left: 5px;
} 
div#sortable .hexagon:nth-child(10) {
    margin-left: 50px;
} 
div#sortable .hexagon:nth-child(14) {
    margin-left: 100px;
} 

请参阅jsfiddle https://jsfiddle.net/vinie23/2jsqmgw2/

请帮帮我。非常感谢您的帮助。在此先感谢。

2 个答案:

答案 0 :(得分:3)

要摆脱Chrome中CSS转换的锯齿状边缘,请添加CSS属性-webkit-backface-visibility: hidden;

小提琴:https://jsfiddle.net/2jsqmgw2/11/

答案 1 :(得分:1)

试试这个:

.hexagon-in2{
background: #6B6A6A;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}

您还可以使用一些向量来获得更清晰的线条和更少的代码,从而优化页面速度/负载。

编辑:解决方案在我之上:-webkit-backface-visibility: hidden;