国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Table of Contents
Mapbox and Three.js in Vue: Implementing the perfect adaptation of 3D models and map perspectives
Home Web Front-end JS Tutorial How to make sure the bottom of a 3D object is fixed on the map using Mapbox and Three.js in Vue?

How to make sure the bottom of a 3D object is fixed on the map using Mapbox and Three.js in Vue?

Apr 04, 2025 pm 06:42 PM
vue ai render function

How to make sure the bottom of a 3D object is fixed on the map using Mapbox and Three.js in Vue?

Mapbox and Three.js in Vue: Implementing the perfect adaptation of 3D models and map perspectives

This article discusses how to synchronize the three-dimensional model with map viewing angle in Vue.js application, combining Mapbox GL JS and Three.js, to ensure that the bottom of the model is always fixed on the map surface and will not be offset due to changes in viewing angles. This is crucial in building geographic information systems or 3D map visualization applications.

Suppose you have successfully rendered the 3D cube to the Mapbox map, but the cube position drifts when the viewing angle moves. The problem lies in the conversion of the Three.js coordinate system and the Mapbox map coordinate system and the setting of model position.

The following code snippet shows a possible problematic code structure, where render function updates the Three.js camera matrix and calculatemodeltransform function performs coordinate conversion:

 render: (gl, matrix) => {
  const m = new THREE.Matrix4().fromArray(matrix);
  const l = new THREE.Matrix4().makeTranslation(modelTransform.translateX, modelTransform.translateY, modelTransform.translateZ)
      .scale(new THREE.Vector3(modelTransform.scale, -modelTransform.scale, modelTransform.scale))
      .multiply(new THREE.Matrix4().makeRotationAxis(new THREE.Vector3(1, 0, 0), modelTransform.rotateX))
      .multiply(new THREE.Matrix4().makeRotationAxis(new THREE.Vector3(0, 1, 0), modelTransform.rotateY))
      .multiply(new THREE.Matrix4().makeRotationAxis(new THREE.Vector3(0, 0, 1), modelTransform.rotateZ));
  customLayer.camera.projectionMatrix = m.multiply(l);
  customLayer.renderer.resetState();
  customLayer.renderer.render(customLayer.scene, customLayer.camera);
  customLayer.map.triggerRepaint();
},

calculatemodeltransform(point) {
  const modelAsMercatorCoordinate = mapboxgl.MercatorCoordinate.fromLngLat([point.lng, point.lat], this.modelAltitude);
  return {
    translateX: modelAsMercatorCoordinate.x,
    translateY: modelAsMercatorCoordinate.y,
    translateZ: modelAsMercatorCoordinate.z,
    rotateX: this.modelRotate[0],
    rotateY: this.modelRotate[1],
    rotateZ: this.modelRotate[2],
    scale: modelAsMercatorCoordinate.meterInMercatorCoordinateUnits()
  };
}

The core problem lies in translateZ of the model and the vertical position when the model is created. We need to adjust the position of the model so that its bottom is precisely aligned with the map plane.

Solution:

  1. Model creation adjustment: When creating a Three.js model, consider the model height and adjust its vertical position (y-axis) so that its bottom is located in the map plane (usually y=0).
 // Create a cube geometry, altitude is the model height const geometry = new THREE.BoxGeometry(20, altitude, 20);
const material = new THREE.MeshStandardMaterial({ color, transparent: true, opacity: 0.8 });
const cube = new THREE.Mesh(geometry, material);

// Key steps: Place the bottom of the cube on the map plane cube.position.y = altitude / 2;
  1. render function adjustment: In the render function, adjust translateZ value according to the model height to ensure that the bottom of the model is always aligned with the map plane.
 const l = new THREE.Matrix4().makeTranslation(modelTransform.translateX, modelTransform.translateY, modelTransform.translateZ - altitude / 2)
  .scale(new THREE.Vector3(modelTransform.scale, -modelTransform.scale, modelTransform.scale))
  // ...Other transformation matrix

Through the above adjustments, even if the map view angle changes, the bottom of the three-dimensional model will remain on the map surface, achieving perfect viewing angle adaptation. Make sure the altitude variable correctly reflects the height of the model. If necessary, the vertical position can be further fine-tuned according to the actual geometry of the model.

The above is the detailed content of How to make sure the bottom of a 3D object is fixed on the map using Mapbox and Three.js in Vue?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

The popularity of the currency circle has returned, why do smart people have begun to quietly increase their positions? Look at the trend from the on-chain data and grasp the next round of wealth password! The popularity of the currency circle has returned, why do smart people have begun to quietly increase their positions? Look at the trend from the on-chain data and grasp the next round of wealth password! Jul 09, 2025 pm 08:30 PM

As the market conditions pick up, more and more smart investors have begun to quietly increase their positions in the currency circle. Many people are wondering what makes them take decisively when most people wait and see? This article will analyze current trends through on-chain data to help readers understand the logic of smart funds, so as to better grasp the next round of potential wealth growth opportunities.

What are the mainstream public chains of cryptocurrencies? The top ten rankings of cryptocurrency mainstream public chains in 2025 What are the mainstream public chains of cryptocurrencies? The top ten rankings of cryptocurrency mainstream public chains in 2025 Jul 10, 2025 pm 08:21 PM

The pattern in the public chain field shows a trend of "one super, many strong ones, and a hundred flowers blooming". Ethereum is still leading with its ecological moat, while Solana, Avalanche and others are challenging performance. Meanwhile, Polkadot, Cosmos, which focuses on interoperability, and Chainlink, which is a critical infrastructure, form a future picture of multiple chains coexisting. For users and developers, choosing which platform is no longer a single choice, but requires a trade-off between performance, cost, security and ecological maturity based on specific needs.

Bitcoin breaks new highs, Dogecoin rebounds strongly, will Ethereum keep up with the pace Bitcoin breaks new highs, Dogecoin rebounds strongly, will Ethereum keep up with the pace Jul 09, 2025 pm 08:24 PM

Recently, Bitcoin hit a new high, Dogecoin ushered in a strong rebound and the market was hot. Next, we will analyze the market drivers and technical aspects to determine whether Ethereum still has opportunities to follow the rise.

Cardano's smart contract evolution: The impact of Alonzo upgrades on 2025 Cardano's smart contract evolution: The impact of Alonzo upgrades on 2025 Jul 10, 2025 pm 07:36 PM

Cardano's Alonzo hard fork upgrade has successfully transformed Cardano from a value transfer network to a fully functional smart contract platform by introducing the Plutus smart contract platform. 1. Plutus is based on Haskell language, with powerful functionality, enhanced security and predictable cost model; 2. After the upgrade, dApps deployment is accelerated, the developer community is expanded, and the DeFi and NFT ecosystems are developing rapidly; 3. Looking ahead to 2025, the Cardano ecosystem will be more mature and diverse. Combined with the improvement of scalability in the Basho era, the enhancement of cross-chain interoperability, the evolution of decentralized governance in the Voltaire era, and the promotion of mainstream adoption by enterprise-level applications, Cardano has

Who issues stablecoins? What are the stablecoins? Who issues stablecoins? What are the stablecoins? Jul 09, 2025 pm 06:24 PM

Stablecoins are crypto assets that maintain price stability by anchoring fiat currencies such as the US dollar. They are mainly divided into three categories: fiat currency collateral, crypto asset collateral and algorithmic stablecoins. 1. USDT is issued by Tether and is the stablecoin with the largest market value and the highest liquidity. 2. USDC is released by the Centre alliance launched by Circle and Coinbase, and is known for its transparency and compliance. 3. DAI is generated by MakerDAO through over-collateralization of crypto assets and is the core currency in the DeFi field. 4. BUSD was launched in partnership with Paxos, and is regulated by the United States but has been discontinued. 5. TUSD achieves high transparency reserve verification through third-party escrow accounts. Users can use centralized exchanges such as Binance, Ouyi, and Huobi

Leading the top 20 token rankings in the 2025 crypto market (Latest update) Leading the top 20 token rankings in the 2025 crypto market (Latest update) Jul 10, 2025 pm 08:48 PM

The top 20 most promising crypto assets in 2025 include BTC, ETH, SOL, etc., mainly covering multiple tracks such as public chains, Layer 2, AI, DeFi and gaming. 1.BTC continues to lead the market with its digital yellow metallicity and popularization of ETFs; 2.ETH consolidates the ecosystem due to its position and upgrade of smart contract platforms; 3.SOL stands out with high-performance public chains and developer communities; 4.LINK is the leader in oracle connecting real data; 5.RNDR builds decentralized GPU network service AI needs; 6.IMX focuses on Web3 games to provide a zero-gas-free environment; 7.ARB leads with mature Layer 2 technology and huge DeFi ecosystem; 8.MATIC has become the value layer of Ethereum through multi-chain evolution

Comparison of the differences and advantages and disadvantages of USDC, DAI, and TUSD (recently updated) Comparison of the differences and advantages and disadvantages of USDC, DAI, and TUSD (recently updated) Jul 10, 2025 pm 09:09 PM

The core difference between USDC, DAI and TUSD lies in the issuance mechanism, collateral assets and risk characteristics. 1. USDC is a centralized stablecoin issued by Circle and is collateralized by cash and short-term treasury bonds. Its advantages are compliance and transparent, strong liquidity, and high stability, but there is a risk of centralized review and single point failure; 2. DAI is a decentralized stablecoin, generated through the MakerDAO protocol, and the collateral is a crypto asset. It has the advantages of anti-censorship, transparency on chain, and permission-free, but it also faces systemic risks, dependence on centralized assets and complexity issues; 3. TUSD is a centralized stablecoin, emphasizing real-time on-chain reserve proof, providing higher frequency transparency verification, but has a small market share and weak liquidity. The three are collateral types and decentralization

What are the mainstream cryptocurrencies in the world? In-depth analysis of cryptocurrency in 2025 (including website) What are the mainstream cryptocurrencies in the world? In-depth analysis of cryptocurrency in 2025 (including website) Jul 10, 2025 pm 08:36 PM

At a time when the digital economy wave swept the world, cryptocurrencies have become the focus of attention from all walks of life with their unique decentralization and transparency. From the initial geek niche experiment to the current financial landscape with a market value of trillions, the evolution of cryptocurrencies is amazing. It not only brings innovations in underlying technologies, but also gives birth to countless innovative applications, which are profoundly affecting all aspects of finance, technology and even social governance.

See all articles