html3d地球代碼示例代碼

以下是一個使用 HTML、CSS 和 JavaScript 實現 3D 地球的示例代碼:


html
<!DOCTYPE html>
<html>
  <head>
    <title>3D Earth</title>
    <style>
      body {
        margin: 0;
        padding: 0;
        perspective: 1000px;
      }
      #earth {
        position: absolute;
        top: 50%;
        left: 50%;
        width: 200px;
        height: 200px;
        margin: -100px 0 0 -100px;
        border-radius: 50%;
        background: url('https://mippu.qunapu.com/upload/2023/05/20230515115327168412280759751.png');
        transform-style: preserve-3d;
        animation: earth 10s linear infinite;
      }
      #earth:before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: url('earthbump.jpg');
        transform: translateZ(1px);
        pointer-events: none;
      }
      #earth:after {
        content: "";
        position: absolute;
        top: 50%;
        left: 50%;
        width: 200px;
        height: 200px;
        margin: -100px 0 0 -100px;
        border-radius: 50%;
        background: url('earthspec.jpg');
        transform: translateZ(-1px);
        pointer-events: none;
      }
      @keyframes earth {
        0% {
          transform: rotateY(0);
        }
        100% {
          transform: rotateY(360deg);
        }
      }
    </style>
  </head>
  <body>
    <div id="earth"></div>
    <script>
      var earth = document.getElementById('earth');
      document.addEventListener('mousemove', function(event) {
        var x = event.clientX - window.innerWidth / 2;
        var y = event.clientY - window.innerHeight / 2;
        earth.style.transform = 'rotateY(' + x / 10 + 'deg) rotateX(' + -y / 10 + 'deg)';
      });
    </script>
  </body>
</html>


該代碼使用了 HTML、CSS 和 JavaScript 語言來實現。其中的元素和語法如下:


- perspective: 設置元素的透視視圖。

- transform-style: 用於指定元素的子元素是否應沿著三維空間中的本地坐標系進行變換。在本例中,用來進行 3D 變換。

- before 和 after: CSS 偽元素,用於在 HTML 元素的前面或後面添加虛擬元素。在本例中,用前置偽元素添加地球表面的凸紋和後置偽元素添加地球表面的光亮效果。

- background: 用於設置元素的背景圖像。

- transform: 用於對元素進行旋轉、縮放、偏移等變換操作。在本例中,用來進行 3D 變換。

- pointer-events: CSS 屬性,控制 HTML 元素如何響應滑鼠事件。在本例中,將透明的凸紋元素設為“不接受滑鼠事件”。

- addEventListener: JavaScript 方法,用於為文檔對象添加事件監聽器。

- clientX/clientY: 滑鼠事件中的屬性,表示滑鼠指針在瀏覽器窗口中的水平/垂直坐標。

- innerWidth/innerHeight: 用於獲取瀏覽器窗口的內部寬度和高度。

- window: 全局對象,代表當前打開的瀏覽器窗口或選項卡。


總之,使用 HTML、CSS 和 JavaScript 實現 3D 地球,用到的主要技術是透視、變換、偽元素和事件監聽等。通過這些技術的靈活組合,可以呈現出逼真的 3D 地球效果,提供更豐富的交互和用戶體驗。

分享給朋友:

“html3d地球代碼示例代碼” 的相關文章

視頻嵌入代碼,簡單的 video 嵌入代碼例子

視頻嵌入代碼,簡單的 video 嵌入代碼例子

視頻嵌入代碼,簡單的 video 嵌入代碼例子:- height:視頻高度。- controls:為 true 時,添加視頻控制條。- source:指定視頻文件路徑和類型,可支持多種類型。- Your browser does not support the video tag:如果用戶的瀏覽器不支持 HTML5  標記,則會顯示此消息。值得註意的是,這種視頻嵌入方式可能會因為用戶瀏覽器兼容性問題而無法播放,因此可能需要添加備用方案,如 Flash 等。同時,需要根據實際情況調整視頻的寬高比例、大小和文件大小等參數,以便更好地適配不同的設備和網絡環境。…

JS跳轉頁面代碼及例子

JS跳轉頁面代碼及例子

JS跳轉頁面是一種很常見的前端交互技術,下面是幾種跳轉頁面的方式:1. 直接修改 `window.location.href` 屬性,2. 使用 `window.location.replace` 方法,此方法會替換當前頁面歷史記錄,不會在瀏覽器歷史記錄中留下痕跡。3. 使用 `window.open` 方法在一個新的瀏覽器窗口或標簽頁中打開一個頁面,4. 如果你需要在某個時間間隔後自動跳轉到目標頁面,可以使用 `setTimeout` 函數。…

一個簡單的html放煙花特效的代碼

一個簡單的html放煙花特效的代碼

以下是一個簡單的html放煙花特效的代碼,代碼說明:1. 使用html和css定義了一個煙花的基本樣式;2. 使用javascript動態生成多個煙花元素,並使用animation讓其展開,模擬煙花爆炸效果;3. 使用setTimeout函數控制煙花爆炸持續時間,並使用setInterval控制煙花爆炸的觸發時間間隔。…

一個簡單的html結婚特效的代碼

一個簡單的html結婚特效的代碼

以下是一個簡單的html結婚特效的代碼:1. 使用html和css定義了一個結婚的基本樣式;2. 分別定義新娘和新郎,並使用background-image設置其背景圖;3. 定義一個心形圖案,並使用animation讓其跳動。…

HTML標簽屬性大全及代碼例子

HTML標簽屬性大全及代碼例子

在HTML中,屬性是在標簽中使用的特殊命令,它們提供了額外的信息以更好地描述標簽的內容和行為。屬性名表示該屬性的名稱,而屬性值表示該屬性要設置的值。HTML標簽屬性有很多種類和用途,它們可以影響標簽的內容、顏色、尺寸、超鏈接、樣式、表單等方面。一些常見的HTML標簽屬性包括:class、id、style、href、src、alt、disabled、checked、selected等等。在學習HTML標簽屬性時,需要註意一些細節和常見錯誤。總而言之,HTML標簽屬性是控制網頁顯示和行為的重要方式。HTML標簽屬性是可以用於定義HTML元素的附加信息。…

html5自學教程步驟及代碼例子

html5自學教程步驟及代碼例子

HTML5是最新的HTML標準,具有更多的功能和特性,讓網頁的制作更加靈活和多樣化。以下是HTML5自學教程的一些步驟:1. 學習HTML基礎知識。在深入學習HTML5之前,你需要先學習HTML的基礎知識,包括HTML文件結構、標簽、屬性和元素等。2. 熟悉HTML5的新特性。HTML5相比於之前的版本有許多新特性,如視頻和音頻標簽、畫布、地理位置、本地存儲等等。3. 編寫示例代碼。理論不如實踐,通過編寫一些簡單的網頁示例代碼,你可以更好地熟悉HTML5的知識點和語法規則。…