


When Vue and Mapbox combine Three.js, how do you ensure that the bottom of a 3D object is fixed on the map without changing with the perspective?
Apr 04, 2025 am 11:42 AMImplement perfect synchronization of 3D models and map viewing in Vue, Mapbox and Three.js
This article discusses how to combine Mapbox GL JS and Three.js in Vue.js application to achieve the effect of keeping the bottom fixed on the map when the map view angle changes. This is crucial for building 3D visualization applications based on geolocation.
Challenge: Change in perspective causes model shift
A common problem when overlaying Three.js models on Mapbox maps is that when you drag or zoom the map, the bottom of the model is offset instead of staying fixed on the map coordinates. This is different from using glTF models directly, which usually better maintain relative position to the map.
Solution: Accurate coordinate transformation and model positioning
Solving this problem requires precise coordinate transformation and model positioning strategies. The following steps and code examples will help you achieve your goals:
Correctness of coordinate system conversion: Make sure your coordinate conversion function (such as
calculatemodeltransform
) correctly converts the 3D model coordinates to the Mercator projection coordinate system used by Mapbox.Adjustment of model position and scaling: The key is to adjust the position and scaling of the Three.js model so that its bottom always corresponds to the map coordinates. The following code snippet shows how to modify the
createcustomlayer
function:
createCustomLayer(index, point, modelTransform) { let color; let altitude; // Set the color and height according to the PM2.5 value (assuming this logic already exists) // ... const customLayer = { id: `custom-layer-${index}`, type: 'custom', renderingMode: '3d', onAdd: (map, gl) => { console.log(`Custom layer added: ${customLayer.id}`); customLayer.camera = new THREE.Camera(); customLayer.scene = new THREE.Scene(); // Add light (ambient and directional light) // ... (assuming this logic already exists) const geometry = new THREE.BoxGeometry(20, altitude, 20); // Adjust the size const material = new THREE.MeshStandardMaterial({ color: color, transparent: true, opacity: 0.8 }); const cube = new THREE.Mesh(geometry, material); // Add contour lines (assuming this logic already exists) // ... // **Key steps: Adjust the position of the model so that the bottom of it is fixed to the map** cube.position.set(0, altitude / 2, 0); //The bottom is located at (0,0,0) customLayer.scene.add(cube); customLayer.map = map; customLayer.renderer = new THREE.WebGLRenderer({ canvas: map.getCanvas(), context: gl, antialias: true }); customLayer.renderer.autoClear = false; }, render: (gl, matrix) => { console.log(`Custom layer rendering: ${customLayer.id}`); const m = new THREE.Matrix4().fromArray(matrix); // ... (Computation of the model transformation matrix, assuming this logic already exists) customLayer.camera.projectionMatrix = m.multiply(l); customLayer.renderer.resetState(); customLayer.renderer.render(customLayer.scene, customLayer.camera); customLayer.map.triggerRepaint(); } }; return customLayer; }
In the code, cube.position.set(0, altitude / 2, 0);
make sure the bottom of the cube is at (0,0,0), and then adjust the height according to altitude
. This allows the bottom of the model to always align with the map coordinate system origin.
- Test and fine-tune: After completing the code modification, test your application and verify that the bottom of the model is always fixed on the map by dragging and zooming the map. It may need to be fine-tuned based on your specific coordinate transformation and model structure.
Through the above steps, you can effectively solve the problem of the Three.js model offset when the map view angle changes, thereby building a more stable and accurate three-dimensional geographic information visualization application. Remember, the key lies in precise coordinate transformation and relative position adjustment of the model.
The above is the detailed content of When Vue and Mapbox combine Three.js, how do you ensure that the bottom of a 3D object is fixed on the map without changing with the perspective?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

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

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

How do novice users choose a safe and reliable stablecoin platform? This article recommends the Top 10 stablecoin platforms in 2025, including Binance, OKX, Bybit, Gate.io, HTX, KuCoin, MEXC, Bitget, CoinEx and ProBit, and compares and analyzes them from dimensions such as security, stablecoin types, liquidity, user experience, fee structure and additional functions. The data comes from CoinGecko, DefiLlama and community evaluation. It is recommended that novices choose platforms that are highly compliant, easy to operate and support Chinese, such as KuCoin and CoinEx, and gradually build confidence through a small number of tests.

Against the backdrop of violent fluctuations in the cryptocurrency market, investors' demand for asset preservation is becoming increasingly prominent. This article aims to answer how to effectively hedge risks in the turbulent currency circle. It will introduce in detail the concept of stablecoin, a core hedge tool, and provide a list of TOP3 stablecoins by analyzing the current highly recognized options in the market. The article will explain how to select and use these stablecoins according to their own needs, so as to better manage risks in an uncertain market environment.

This article will discuss the world's mainstream stablecoins and analyze which stablecoins have the risk aversion attribute of "gold substitute" in the market downward cycle (bear market). We will explain how to judge and choose a relatively stable value storage tool in a bear market by comparing the market value, endorsement mechanism, transparency, and comprehensively combining common views on the Internet, and explain this analysis process.

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.

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.

This article will introduce several mainstream stablecoins and explain in depth how to evaluate the security of a stablecoin from multiple dimensions such as transparency and compliance, so as to help you understand which stablecoins are generally considered relatively reliable choices in the market, and learn how to judge their "hazard-haven" attributes on your own.

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.

Stable coins maintain price stability by anchoring fiat currencies such as the US dollar, which are mainly divided into three categories: 1. Fiat currency collateralization types such as USDT and USDC; 2. Cryptocurrency collateralization types such as DAI; 3. Algorithm types have higher risks. Mainstream stablecoins include USDT with the highest market value and the best liquidity. USDC is known for its compliance and transparency. DAI relies on the decentralized mechanism. TUSD adopts on-chain real-time audit. BUSD is gradually withdrawing from the market due to supervision. USDP is known for its high compliance and security. Both are widely circulated on mainstream exchanges.
