xgqfrms™, xgqfrms® : xgqfrms's offical website of cnblogs! xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!

SVG (viewBox) & DOM (viewport)

SVG (viewBox) & DOM (viewport)

circle

"use strict";

/**
 *
 * @author xgqfrms
 * @license MIT
 * @copyright xgqfrms
 * @created 2020-02-10
 * @modified 2020-02-11
 *
 * @description
 * @augments
 * @example
 * @link http://xahlee.info/js/js_scritping_svg_basics.html
 * @link https://developer.mozilla.org/zh-CN/docs/Web/API/Element/insertAdjacentHTML
 *
 */

// 容器小,circle 大,导致 circle 被剪切
const svgStr = `<svg width="100" height="100"><circle cx="80" cy="80" r="30" fill="grey" stroke="purple"></circle></svg>`;

// ? viewBox 缩放比例
// 容器大,内容小,完全绘制,逆时针,顺时针 ?
const svgMeta = `<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 100 100" width="100%" height="100%"><circle cx="100" cy="100" r="50" fill="red" stroke="green"></circle></svg>`;

const body = document.querySelector(`body`);

body.insertAdjacentHTML(`beforeend`, svgStr);

body.insertAdjacentHTML(`beforeend`, svgMeta);


const jsCreatSVG = () => {
  // create the svg element, namespace
  const svg = document.createElementNS("http://www.w3.org/2000/svg", "svg");

  // meta
  svg.setAttribute("version", "1.1");
  svg.setAttribute("xmlns", "http://www.w3.org/2000/svg");
  svg.setAttribute("xmlns:xlink", "http://www.w3.org/1999/xlink");
  svg.setAttribute("viewBox", "0 0 100 100");

  // set width and height
  svg.setAttribute("width", "100");
  svg.setAttribute("height", "100");


  // create a circle
  const circle = document.createElementNS("http://www.w3.org/2000/svg", "circle");

  circle.setAttribute("cx", "80");
  circle.setAttribute("cy", "80");
  circle.setAttribute("r", "30");
  circle.setAttribute("fill", "red");

  // attach it to the container
  svg.appendChild(circle);

  // attach container to document
  document.querySelector(`body`).appendChild(svg);
};

https://codepen.io/xgqfrms/pen/gOppybr?editors=0010


SVG viewBox & DOM viewport

viewBox

https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/viewBox

https://www.sarasoueidan.com/blog/svg-coordinate-systems/

https://webdesign.tutsplus.com/tutorials/svg-viewport-and-viewbox-for-beginners--cms-30844

http://tutorials.jenkov.com/svg/svg-viewport-view-box.html



©xgqfrms 2012-2020

www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!


posted @   xgqfrms  阅读(221)  评论(5编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2019-02-11 screen.height && screen.width
2019-02-11 优先级:P0
2019-02-11 CSS3 Selectors All In One
点击右上角即可分享
微信分享提示