javascript - 使用 CSS/Javascript 显示环绕球体的图像

标签 javascript css css-transforms

我知道这可以通过 three.js 实现,但似乎 three.js 最大化了一个网格球体并且图像有点失真。如果可能的话,我也宁愿只使用 CSS。

这可以通过 CSS 转换来完成吗?理想情况下,我想将它从平面图像动画化为球体,这样可以轻松使用 CSS 过渡动画的东西会很棒。

最佳答案

我在 codepen 上找到了一个很好的例子来说明如何用 CSS 做到这一点:http://codepen.io/donovanh/pen/GBIiv .它实际上并没有将图像包裹在 3d 中,但对于我的目的来说它看起来足够好。

这是相关的 html/css:

<section class="stage">
  <figure class="ball"><span class="shadow"></span></figure>
</section>

.ball {
  display: inline-block;
  width: 100%;
  height: 100%;
  margin: 0;
  border-radius: 50%;
  position: relative;
  -webkit-transform-style: preserve-3d;
  background: url('https://alxgroup.net/gto-range-builder/images/treeSS.png') repeat-x;
  background-size: auto 100%;
  -webkit-animation: move-map 30s infinite linear;
  -moz-animation: move-map 30s infinite linear;
  -o-animation: move-map 30s infinite linear;
  -ms-animation: move-map 30s infinite linear;
  animation: move-map 30s infinite linear;
}

.ball:before {
  content: "";
  position: absolute;
  top: 0%;
  left: 0%;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  box-shadow: -40px 10px 70px 10px rgba(0,0,0,0.5) inset;
  z-index: 2;
}

.ball:after {
  content: "";
  position: absolute;
  border-radius: 50%;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  -webkit-filter: blur(0);
  opacity: 0.3;
  background: radial-gradient(circle at 50% 80%, #81e8f6, #76deef 10%, #055194 66%, #062745 100%);
}

.ball .shadow {
  position: absolute;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at 50% 50%, rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.1) 40%, rgba(0, 0, 0, 0) 50%);
  -webkit-transform: rotateX(90deg) translateZ(-150px);
  -moz-transform: rotateX(90deg) translateZ(-150px);
  -ms-transform: rotateX(90deg) translateZ(-150px);
  -o-transform: rotateX(90deg) translateZ(-150px);
  transform: rotateX(90deg) translateZ(-150px);
  z-index: -1;
}
body {
  width: 300px;
  margin: 20px auto;
  background: linear-gradient(to bottom, rgba(100, 100, 100, 0.2) 0%, rgba(255, 255, 255, 0.5) 40%, #ffffff 100%);
  background-repeat: no-repeat;
}

.stage {
  width: 300px;
  height: 300px;
  display: inline-block;
  margin: 20px;
  -webkit-perspective: 1200px;
  -moz-perspective: 1200px;
  -ms-perspective: 1200px;
  -o-perspective: 1200px;
  perspective: 1200px;
  -webkit-perspective-origin: 50% 50%;
  -moz-perspective-origin: 50% 50%;
  -ms-perspective-origin: 50% 50%;
  -o-perspective-origin: 50% 50%;
  perspective-origin: 50% 50%;
}

@-moz-keyframes move-map {
  0% {
    background-position: -849px 0; }

  100% {
    background-position: 0 0; } }

@-webkit-keyframes move-map {
  0% {
    background-position: 0 0; }
  100% {
    background-position: -849px 0; }
}


@-o-keyframes move-map {
  0% {
    background-position: -849px 0; }

  100% {
    background-position: 0 0; } }

@-ms-keyframes move-map {
  0% {
    background-position: -849px 0; }

  100% {
    background-position: 0 0; } }

@keyframes move-map {
  0% {
    background-position: -849px 0; }

  100% {
    background-position: 0 0; } }

关于javascript - 使用 CSS/Javascript 显示环绕球体的图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24561723/

相关文章:

javascript - 如何在 Raphael js 中制作图像圆圈

css - 如何在 CSS 中应用多个变换?

html - 消除分类多个倾斜图像的末端

javascript - 将 Javascript 正则表达式转换为 C# 正则表达式

javascript - 解析预定的后台作业

javascript - 如何使新的 DOM 元素认为它驻留在与 js 和 css 不同的域中

html - 带有背景图片的 CSS 对 Angular 线部分分隔符

javascript - React - 元素类型无效 : expected a string

css - 如何调整文本的垂直对齐方式以纠正字体的错位?

css - 仅在溢出时应用悬停