Angular页面渲染或生命周期问题:当重新进入页面时,SVGGraphicsElement.getScreenCTM返回错误的平移值。
创始人
2024-10-30 11:30:33
0

问题描述: 当重新进入Angular页面时,使用SVGGraphicsElement.getScreenCTM方法获取SVG元素的平移值时,返回错误的值。

解决方法:

  1. 在Angular组件中,使用ngAfterViewInit生命周期钩子来处理SVG元素的渲染和获取平移值的逻辑。
import { Component, AfterViewInit, ViewChild, ElementRef } from '@angular/core';

@Component({
  selector: 'app-svg-component',
  template: `
    
      
    
  `,
})
export class SvgComponent implements AfterViewInit {
  @ViewChild('svgElement') svgElementRef: ElementRef;

  ngAfterViewInit(): void {
    this.getSVGElementTranslation();
  }

  getSVGElementTranslation(): void {
    const svgElement = this.svgElementRef.nativeElement;
    const gElement = svgElement.querySelector('g'); // Assuming the SVG element is inside a  element

    if (gElement) {
      const ctm = gElement.getScreenCTM();
      const translationX = ctm.e;
      const translationY = ctm.f;

      console.log('Translation X:', translationX);
      console.log('Translation Y:', translationY);
    }
  }
}
  1. 使用ngAfterViewChecked生命周期钩子来处理SVG元素的渲染和获取平移值的逻辑。
import { Component, AfterViewChecked, ViewChild, ElementRef } from '@angular/core';

@Component({
  selector: 'app-svg-component',
  template: `
    
      
    
  `,
})
export class SvgComponent implements AfterViewChecked {
  @ViewChild('svgElement') svgElementRef: ElementRef;

  ngAfterViewChecked(): void {
    this.getSVGElementTranslation();
  }

  getSVGElementTranslation(): void {
    const svgElement = this.svgElementRef.nativeElement;
    const gElement = svgElement.querySelector('g'); // Assuming the SVG element is inside a  element

    if (gElement) {
      const ctm = gElement.getScreenCTM();
      const translationX = ctm.e;
      const translationY = ctm.f;

      console.log('Translation X:', translationX);
      console.log('Translation Y:', translationY);
    }
  }
}

这两种方法都会在Angular组件初始化完成后,或在Angular渲染周期内检查并获取SVG元素的平移值。根据需要选择适合的生命周期钩子函数。

相关内容

热门资讯

透视方式!aapoker辅助插... 透视方式!aapoker辅助插件工具,hhpoker有后台操控吗(透视)一直存在有挂(哔哩哔哩)1、...
透视资料!悦扑克脚本,aapo... 透视资料!悦扑克脚本,aapoker怎么设置抽水(透视)总是存在有挂(哔哩哔哩)1、玩家可以在aap...
透视总结!wepoker怎么增... 透视总结!wepoker怎么增加运气,wepoker可以透视码(透视)其实真的有挂(哔哩哔哩)1、金...
透视资料!大菠萝免费辅助,hh... 透视资料!大菠萝免费辅助,hhpoker是正品吗(透视)其实是有挂(哔哩哔哩);1、进入游戏-大厅左...
透视法子!we-poker辅助... 透视法子!we-poker辅助器,黑侠破解wepoker(透视)其实真的有挂(哔哩哔哩)1、完成黑侠...
透视指南!epoker有透视吗... 透视指南!epoker有透视吗,德普之星透视辅助(透视)好像存在有挂(哔哩哔哩)透视指南!epoke...
透视学习!wepoker有脚本... 透视学习!wepoker有脚本吗,德普之星透视辅助软件(透视)竟然有挂(哔哩哔哩)1、全新机制【德普...
透视手段!poker worl... 透视手段!poker world辅助器,wepoker辅助器安装包(透视)果然是真的挂(哔哩哔哩)1...
透视项目!wepokerplu... 透视项目!wepokerplus辅助,newpoker怎么安装脚本(透视)真是真的是有挂(哔哩哔哩)...
透视秘籍!aapoker如何设... 透视秘籍!aapoker如何设置胜率,hardrock作必弊(透视)其实是真的挂(哔哩哔哩)1、aa...