- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个包含一条路径和一个多边形的 svg。其中每一个都有一个类,我正在使用 CSS3 转换来为它们设置动画。
这在 Chrome 和 Safari 中运行良好。在 IE 和 Opera 中,转换根本不会发生,它只是改变颜色,这很好 - 虽然不是很理想,但至少看起来不好。
但是,在 Firefox 上,形状从左上角开始动画,并被 SVG 的边缘裁剪。如果您不包含 -webkit-transform-origin,这与您在 Chrome 上的行为相同,但在添加 -moz-transform-origin 后问题仍然存在。
我的 HTML:
<div class="overlay">
<svg version="1.0" width="62" height="62" viewBox="0 0 62 62" xml:space="preserve" class="svg">
<defs id="defs3003"></defs>
<path d="M 31,6 C 17.192,6 6,17.192 6,31 6,44.808 17.192,56 31,56 44.808,56 56,44.808 56,31 56,17.192 44.808,6 31,6 m 0,45.313 C 19.781,51.313 10.687,42.219 10.687,31 10.687,19.781 19.781,10.688 31,10.688 c 11.219,0 20.313,9.093 20.313,20.312 0,11.219 -9.094,20.313 -20.313,20.313" id="path2997" style="fill:#ffffff" class="ring"></path>
<polygon points="22.75,41.938 22.75,20.063 41.5,31 " transform="translate(0.86055955,-5e-4)" id="polygon2999" style="fill:#ffffff" class="inner"></polygon>
</svg>
</div>
我的 CSS:
.overlay {
position: relative;
background: #333;
top: 0;
left: 0;
width: 200px;
height: 200px;
transition: all linear 0.3s;
-webkit-transform: translateZ(0);
-webkit-backface-visibility: hidden;
-webkit-perspective: 1000;
}
.overlay .svg {
position: absolute;
left: 50%;
top: 50%;
margin-left: -32px;
margin-top: -32px;
}
.overlay .svg .inner {
-webkit-transform-origin: 50% 50%;
-moz-transform-origin: 50% 50%;
transform-origin: 50% 50%;
-webkit-transform: scale(0);
-moz-transform: scale(0);
-ms-transform: scale(0);
-o-transform: scale(0);
transform: scale(0);
-webkit-transition: all linear 0.2s;
-moz-transition: all linear 0.2s;
-ms-transition: all linear 0.2s;
-o-transition: all linear 0.2s;
transition: all linear 0.2s;
-webkit-backface-visibility: hidden;
fill: #fff !important;
}
.overlay:hover .svg .inner {
-webkit-transform: scale(1);
-moz-transform: scale(1);
-ms-transform: scale(1);
-o-transform: scale(1);
transform: scale(1);
-webkit-transition: all linear 0.1s;
-moz-transition: all linear 0.1s;
-ms-transition: all linear 0.1s;
-o-transition: all linear 0.1s;
transition: all linear 0.1s;
left: 50%;
top: 50%;
margin-left: -32px;
margin-top: -32px;
fill: #FA0 !important;
}
.overlay .svg .ring {
-webkit-transform-origin: 50% 50%;
-moz-transform-origin: 50% 50%;
transform-origin: 50% 50%;
-webkit-transform: scale(1);
-moz-transform: scale(1);
-ms-transform: scale(1);
-o-transform: scale(1);
transform: scale(1);
-webkit-transition: all linear 0.25s;
-moz-transition: all linear 0.25s;
-ms-transition: all linear 0.25s;
-o-transition: all linear 0.25s;
transition: all linear 0.25s;
fill: #fff !important;
}
.overlay:hover .svg .ring {
-webkit-transform: scale(1.2);
-moz-transform: scale(1.2);
-ms-transform: scale(1.2);
-o-transform: scale(1.2);
transform: scale(1.2);
-webkit-transition: all linear 0.15s;
-moz-transition: all linear 0.15s;
-ms-transition: all linear 0.15s;
-o-transition: all linear 0.15s;
transition: all linear 0.15s;
fill: #FA0 !important;
}
最佳答案
我在使用 SVG 进行过渡时遇到了一些麻烦。您试过只使用 HTML 吗?
我已经将我们的代码更改为仅使用 HTML。 http://jsfiddle.net/labmorales/kkVnY/1/
HTML
<div class="overlay">
<div class="svg">
<div class="ring">
<div class="inner"></div>
</div>
</div>
</div>
CSS
.overlay {
position: relative;
background: #333;
top: 0;
left: 0;
width: 200px;
height: 200px;
transition: all linear 0.3s;
-webkit-transform: translateZ(0);
-webkit-backface-visibility: hidden;
-webkit-perspective: 1000;
}
.overlay .svg {
position: absolute;
left: 50%;
top: 50%;
margin-left: -32px;
margin-top: -32px;
width: 62px;
height: 62px;
}
.overlay .svg .inner {
-webkit-transform-origin: 50% 50%;
-moz-transform-origin: 32px 32px;
transform-origin: 50% 50%;
-webkit-transform: scale(0);
-moz-transform: scale(0);
-ms-transform: scale(0);
-o-transform: scale(0);
transform: scale(0);
-webkit-transition: all linear 0.2s;
-moz-transition: all linear 0.2s;
-ms-transition: all linear 0.2s;
-o-transition: all linear 0.2s;
transition: all linear 0.2s;
-webkit-backface-visibility: hidden;
width: 0;
height: 0;
border-top: 12px solid transparent;
border-bottom: 12px solid transparent;
border-left: 15px solid #fff;
margin: 13px 24px;
/*background: #fff !important;*/
}
.overlay:hover .svg .inner {
-webkit-transform: scale(1);
-moz-transform: scale(1);
-ms-transform: scale(1);
-o-transform: scale(1);
transform: scale(1);
-webkit-transition: all linear 0.1s;
-moz-transition: all linear 0.1s;
-ms-transition: all linear 0.1s;
-o-transition: all linear 0.1s;
transition: all linear 0.1s;
left: 50%;
top: 50%;
border-left: 15px solid #FA0;
/*background: #FA0 !important;*/
}
.overlay .svg .ring {
border-radius: 50%;
border: 3px solid #fff;
height: 50px;
-webkit-transform-origin: 50% 50%;
-moz-transform-origin: 32px 32px;
transform-origin: 50% 50%;
-webkit-transform: scale(1);
-moz-transform: scale(1);
-ms-transform: scale(1);
-o-transform: scale(1);
transform: scale(1);
-webkit-transition: all linear 0.25s;
-moz-transition: all linear 0.25s;
-ms-transition: all linear 0.25s;
-o-transition: all linear 0.25s;
transition: all linear 0.25s;
/*fill: #fff !important;*/
}
.overlay:hover .svg .ring {
-webkit-transform: scale(1.2);
-moz-transform: scale(1.2);
-ms-transform: scale(1.2);
-o-transform: scale(1.2);
transform: scale(1.2);
-webkit-transition: all linear 0.15s;
-moz-transition: all linear 0.15s;
-ms-transition: all linear 0.15s;
-o-transition: all linear 0.15s;
transition: all linear 0.15s;
/*fill: #FA0 !important;*/
border-color: #FA0 !important;
}
在 Windows7 上的 Firefox、Chrome、IE9(无转换)上工作。希望对您有所帮助!
关于css - -moz-transform-origin 对 SVG 转换没有影响,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21020873/
XMLHttpRequest cannot load http://localhost:8080/api/test. Origin http://localhost:3000 is not allow
Git diff 似乎在比较时返回不同的变化: git diff origin/master ... origin/branch git diff origin/master...origin/bra
我正在研究 3.1 Git Branching - Branches in a Nutshell 中的 git 分支概念 我正在玩虚拟存储库。 git log --oneline --decorate
我知道有很多类似的问题,唯一的区别是我从 **same ** 域提供的两个页面得到了这个。这可以在下面的示例中看到。 Uncaught DOMException: Blocked a fram
我被要求使用 Fork Workflow,即我必须处理具有相同或相似名称的多个分支。我为什么要使用这些不同的变体? 以下是不同命名约定的一些示例: 我的分支机构 起源我的分支 起源/我的分支机构 远程
这个问题已经有答案了: How do I delete a Git branch locally and remotely? (41 个回答) 已关闭 9 年前。 好的,我已经创建了一个 origin
这是我关于如何让 lerna 在 Jenkins 中运行的一系列问题的一部分。 上一期: lerna publish on Jenkins "git remote update" Fails "Cou
当我尝试从我的 Angular 6 应用程序访问 Webhdfs 时,我收到如下所示的错误。在我看来,我几乎尝试了所有方法,包括更改 core-site.xml 和 hdfs-site.xml 中的设
我正在从不同的来源向我的服务器发出 Ajax POST 请求以供用户登录。我已经在我的 application_controller.rb 中正确设置了 Cross Origin header : d
我刚刚克隆了一个存储库并在 Git 中开始了一个新分支。我已经这样做了很多次而没有遇到问题。今晚当我尝试使用 git branch --set-upstream develop origin/deve
我对 Git 还很陌生,但仍在掌握它的窍门。我最近才开始使用分支机构,遇到了一些问题。 我有两个开发系统,一个 Ubuntu 桌面和一个 MacBookPro。我在 Ubuntu 系统上的一个新的 o
这个问题在这里已经有了答案: Why does "git push main" work on GitHub when "git push master" does not? Also what i
我想从我的应用访问一个 API。 curl 请求是: curl --request POST https://... --header 'Authorization: Token ...'
我试图理解的遗留 makefile 具有 -Wl,-z,origin,-rpath,'$ORIGIN/../lib' 好的,我看到 -Wl 表示以下是链接器选项;逗号将替换为空格。 GNU ld 的联
我正在寻找 OpenShift Origin 和 OpenShift Enterprise 之间的主要区别。我知道第一个是开源的,后者是商业版。与开源版本相比,OpenShift Enterprise
我在 Sourcetree 中有这个历史图表: Sourcetree graph 如何将最后一次提交从 origin/development 复制到 origin/master 分支? 第二个问题:图
运行 git 命令时空格和斜杠有什么区别? 我有时会看到 git push origin master(这是一个空格) 还有其他时候我看到 git rebase origin/master(使用斜杠)
根据文档,git pull 执行 git fetch 然后执行 git merge,但是在那种情况下执行 git pull origin master 应该执行 git fetch origin ma
我正在使用我的 git 存储库,并在早些时候对 master 分支进行了相当多的提交。现在我意识到它有点太吵了,我想将所有这些 merge 到一个提交中。 102381 commit z .... 1
我制作了一个小的 xslt 文件来创建一个名为 weather.xsl 的 html 输出,代码如下: 我想将 html 输出加载到 html 文件中的 div 中,我正在尝试
我是一名优秀的程序员,十分优秀!