Angular+ThreeJS-画布渲染位置错误
创始人
2024-10-21 01:30:49
0

在Angular中使用Three JS时,很容易出现渲染问题,特别是当尝试使用CSS样式更改画布大小和位置时。如果遇到画布渲染在错误位置的问题,可以尝试以下几种解决方法。

  1. 设置画布大小和位置

在Component中,可以使用ViewChild获取Canvas元素并设置其大小和位置,如下所示:

import { Component, ViewChild, ElementRef } from '@angular/core';
import * as THREE from 'three';

@Component({
  selector: 'app-three-canvas',
  template: '',
  styleUrls:['./three-canvas.component.css'] 
})
export class ThreeCanvasComponent {
  @ViewChild('canvas') canvasRef: ElementRef;

  private scene: THREE.Scene;
  private camera: THREE.PerspectiveCamera;
  private renderer: THREE.WebGLRenderer;
  private mesh: THREE.Mesh;

  ngAfterViewInit(): void {
    this.init();
    this.animate();
  }

  private init(): void {
    const width = this.canvasRef.nativeElement.clientWidth; //获取canvas宽度
    const height = this.canvasRef.nativeElement.clientHeight; //获取canvas高度

    //创建场景
    this.scene = new THREE.Scene();

    //创建相机
    this.camera = new THREE.PerspectiveCamera(75, width / height, 0.1, 1000);
    this.camera.position.z = 5;

    //创建网格
    const geometry = new THREE.BoxGeometry();
    const material = new THREE.MeshBasicMaterial({ color: 0x00ff00 });
    this.mesh = new THREE.Mesh(geometry, material);
    this.scene.add(this.mesh);

    //创建渲染器
    this.renderer = new THREE.WebGLRenderer({
      canvas: this.canvasRef.nativeElement //注意这里不要再document中获取canvas
    });
    this.renderer.setSize(width, height);
  }

  private animate(): void {
    requestAnimationFrame(() => this.animate());
    this.render();
  }

  private render(): void {
    this.mesh.rotation.x += 0.01;
    this.mesh.rotation.y += 0.01;
    this.renderer

相关内容

热门资讯

据公告内容!智星德州插件怎么下... 据公告内容!智星德州插件怎么下载,wepoker插件程序,攻略辅助神器(有挂透视)-哔哩哔哩1、智星...
据统计!欢聚水鱼辅助插件(辅助... 您好,欢聚水鱼辅助插件这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多玩...
透视最新!uupoker透视,... 透视最新!uupoker透视,小程序微乐辅助器ios,指南辅助软件(有挂猫腻)-哔哩哔哩在进入小程序...
为切实保障!蜀山四川辅助脚本视... 为切实保障!蜀山四川辅助脚本视频教学(辅助)竟然是有辅助挂(有挂规律)-哔哩哔哩进入游戏-大厅左侧-...
现有关情况通报如下!xpoke... 现有关情况通报如下!xpoker辅助控制,途游大作战辅助,学习辅助攻略(有挂解惑)-哔哩哔哩1、途游...
昨日!新星游挂多少钱(辅助)总... 昨日!新星游挂多少钱(辅助)总是是真的辅助神器(有挂分享)-哔哩哔哩1)新星游挂多少钱辅助插件:进一...
透视挂透视!pokemmo辅助... 透视挂透视!pokemmo辅助官网,蜀山四川小程序作必弊视频,操作辅助脚本(有挂方法)-哔哩哔哩在进...
受玩家影响!悟空大厅怎么挂辅助... 受玩家影响!悟空大厅怎么挂辅助(辅助)其实是有辅助挂(的确有挂)-哔哩哔哩1、悟空大厅怎么挂辅助免费...
这一问题亟待解决!花舍辅助(辅... 这一问题亟待解决!花舍辅助(辅助)真是真的有辅助app(真的有挂)-哔哩哔哩1、完成花舍辅助有辅助插...
透视神器!竞技联盟辅助插件,忆... 透视神器!竞技联盟辅助插件,忆游十三道辅助,学习辅助教程(有挂解密)-哔哩哔哩运竞技联盟辅助插件辅助...