当前位置: 首页 > news >正文

深圳网站建设clh关键词挖掘方法

深圳网站建设clh,关键词挖掘方法,怎么样自己制作网页,营销策划方案1500字上节课案例创建标签的方式,是把一张图片作为Sprite精灵模型的颜色贴图,本节给大家演示把Canvas画布作为Sprite精灵模型的颜色贴图,实现一个标签。 注意:本节课主要是技术方案讲解,默认你有Canvas基础,如果没有Canvas基…

上节课案例创建标签的方式,是把一张图片作为Sprite精灵模型的颜色贴图,本节给大家演示把Canvas画布作为Sprite精灵模型的颜色贴图,实现一个标签。

注意:本节课主要是技术方案讲解,默认你有Canvas基础,如果没有Canvas基础,可以学习之后再来学习本节课内容。

Canvas画布绘制一个标签

你可以使用Canvas绘制特定轮廓的标签,比如加上指引线或箭头,可以输入特定文字。

下面代码自动适配了不同长度的文字标注,文字符号越多,canvas画布越长。

// 生成一个canvas对象,标注文字为参数name
function createCanvas(name) {/*** 创建一个canvas对象,绘制几何图案或添加文字*/const canvas = document.createElement("canvas");const arr = name.split(""); //分割为单独字符串let num = 0;const reg = /[\u4e00-\u9fa5]/;for (let i = 0; i < arr.length; i++) {if (reg.test(arr[i])) { //判断是不是汉字num += 1;} else {num += 0.5; //英文字母或数字累加0.5}}// 根据字符串符号类型和数量、文字font-size大小来设置canvas画布宽高度const h = 80; //根据渲染像素大小设置,过大性能差,过小不清晰const w = h + num * 32;canvas.width = w;canvas.height = h;const h1 = h * 0.8;const c = canvas.getContext('2d');// 定义轮廓颜色,黑色半透明c.fillStyle = "rgba(0,0,0,0.5)";// 绘制半圆+矩形轮廓const R = h1 / 2;c.arc(R, R, R, -Math.PI / 2, Math.PI / 2, true); //顺时针半圆c.arc(w - R, R, R, Math.PI / 2, -Math.PI / 2, true); //顺时针半圆c.fill();// 绘制箭头c.beginPath();const h2 = h - h1;c.moveTo(w / 2 - h2 * 0.6, h1);c.lineTo(w / 2 + h2 * 0.6, h1);c.lineTo(w / 2, h);c.fill();// 文字c.beginPath();c.translate(w / 2, h1 / 2);c.fillStyle = "#ffffff"; //文本填充颜色c.font = "normal 32px 宋体"; //字体样式设置c.textBaseline = "middle"; //文本与fillText定义的纵坐标c.textAlign = "center"; //文本居中(以fillText定义的横坐标)c.fillText(name, 0, 0);return canvas;
}
const canvas = createCanvas('设备A')

CanvasTexture把canvas转化为纹理对象

canvas画布作为CanvasTexture的参数创建一个纹理对象,本质上你可以理解为CanvasTexture把canvas画布当做图片,读取参数canvas画布上的像素值,创建纹理贴图Texture

loader.load("../工厂.glb", function (gltf) {model.add(gltf.scene);const canvas = createCanvas('设备A');//创建一个canvas画布// canvas画布作为CanvasTexture的参数创建一个纹理对象// 本质上你可以理解为CanvasTexture读取参数canvas画布上的像素值const texture = new THREE.CanvasTexture(canvas);const spriteMaterial = new THREE.SpriteMaterial({map: texture,});const sprite = new THREE.Sprite(spriteMaterial);
})

精灵模型尺寸和位置设置

精灵模型尺寸和位置设置具体思路可以参考上节课讲解。

注意精灵模型宽高比和canvas画布宽高比保持一致即可。

const y = 4;//精灵y方向尺寸
// sprite宽高比和canvas画布保持一致
const x = canvas.width/canvas.height*y;//精灵x方向尺寸
sprite.scale.set(x, y, 1);// 控制精灵大小
sprite.position.y = y / 2; //标签底部箭头和空对象标注点重合  
const obj = gltf.scene.getObjectByName('设备A标注'); // obj是建模软件中创建的一个空对象
obj.add(sprite); //tag会标注在空对象obj对应的位置

cavnas精灵标签封装(标注多个)

封装一个创建cavnas精灵标签的函数,可以根据需要调用,标注任何需要标注的地方。

import * as THREE from 'three';
import createCanvas from './canvas';
// 标注位置对应的模型对象obj
// name:标注文字
function createSprite(obj,name) {const canvas = createCanvas(name);//创建一个canvas画布// canvas画布作为CanvasTexture的参数创建一个纹理对象const texture = new THREE.CanvasTexture(canvas);const spriteMaterial = new THREE.SpriteMaterial({map: texture,});const sprite = new THREE.Sprite(spriteMaterial);// 控制精灵大小(sprite宽高比和canvas画布保持一致)const s = 0.05;//通过canvas宽高度缩放后,设置sprite.scale,避免图文宽高比变形const x = canvas.width*s;const y = canvas.height*s;sprite.scale.set(x, y, 1);sprite.position.y = y / 2; //标签底部箭头和空对象标注点重合  obj.add(sprite); //tag会标注在空对象obj对应的位置
}export default createSprite;

Canvas包含外部图片

如果Canvas包含外部图片作为背景,注意创建CanvasTexture的时候,不管你的代码结构怎么组织,主要要等图像加载完成再执行THREE.CanvasTexture(canvas),如果还未加载完成,创建纹理时候,读取画布像素时候,会不包含图片。

// 生成一个canvas对象,标注文字为参数name
function createCanvas(img,name) {/*** 创建一个canvas对象,绘制几何图案或添加文字*/const canvas = document.createElement("canvas");const w = 140; //根据渲染像素大小设置,过大性能差,过小不清晰const h = 80;canvas.width = w;canvas.height = h;const h1 = h * 0.8;const c = canvas.getContext('2d');c.fillStyle = "rgba(0,0,0,0.0)"; //背景透明c.fillRect(0, 0, w, h);c.drawImage(img, 0, 0, w, h);//图片绘制到canvas画布上// 文字c.beginPath();c.translate(w / 2, h1 / 2);c.fillStyle = "#ffffff"; //文本填充颜色c.font = "normal 32px 宋体"; //字体样式设置c.textBaseline = "middle"; //文本与fillText定义的纵坐标c.textAlign = "center"; //文本居中(以fillText定义的横坐标)c.fillText(name, 0, 0);return canvas;
}
  const img = new Image();img.src = "./标签箭头背景.png";img.onload = function () {const canvas = createCanvas(img,'设备A');//创建一个canvas画布// 图片加载完成后,读取canvas像素数据创建CanvasTextureconst texture = new THREE.CanvasTexture(canvas);...const sprite = new THREE.Sprite(spriteMaterial);...}

文章转载自:
http://slowly.tyjp.cn
http://debra.tyjp.cn
http://rarebit.tyjp.cn
http://pretermission.tyjp.cn
http://pianoforte.tyjp.cn
http://comtist.tyjp.cn
http://evagination.tyjp.cn
http://automatise.tyjp.cn
http://greeneland.tyjp.cn
http://laetare.tyjp.cn
http://pctools.tyjp.cn
http://oophoritis.tyjp.cn
http://cram.tyjp.cn
http://frore.tyjp.cn
http://windstorm.tyjp.cn
http://phelps.tyjp.cn
http://factitiously.tyjp.cn
http://anthrax.tyjp.cn
http://polyhydric.tyjp.cn
http://sepal.tyjp.cn
http://pudendum.tyjp.cn
http://seminomad.tyjp.cn
http://grallatorial.tyjp.cn
http://reappoint.tyjp.cn
http://viridity.tyjp.cn
http://legman.tyjp.cn
http://onfall.tyjp.cn
http://formal.tyjp.cn
http://chaffcutter.tyjp.cn
http://exoderm.tyjp.cn
http://filicite.tyjp.cn
http://codicillary.tyjp.cn
http://acquiescently.tyjp.cn
http://zymoid.tyjp.cn
http://somewise.tyjp.cn
http://aurific.tyjp.cn
http://nilometer.tyjp.cn
http://uncleanness.tyjp.cn
http://messerschmitt.tyjp.cn
http://multicentre.tyjp.cn
http://thiokol.tyjp.cn
http://creesh.tyjp.cn
http://employless.tyjp.cn
http://reinvade.tyjp.cn
http://ectoproct.tyjp.cn
http://pawl.tyjp.cn
http://scatterbrain.tyjp.cn
http://siloam.tyjp.cn
http://giocoso.tyjp.cn
http://mwalimu.tyjp.cn
http://dissatisfy.tyjp.cn
http://categorize.tyjp.cn
http://pediarchy.tyjp.cn
http://orifice.tyjp.cn
http://komatsu.tyjp.cn
http://ubon.tyjp.cn
http://prague.tyjp.cn
http://cystamine.tyjp.cn
http://fibrino.tyjp.cn
http://neurochemical.tyjp.cn
http://bedpan.tyjp.cn
http://hongi.tyjp.cn
http://outvie.tyjp.cn
http://lieutenancy.tyjp.cn
http://mesodontism.tyjp.cn
http://repellancy.tyjp.cn
http://inerasable.tyjp.cn
http://presbyterian.tyjp.cn
http://dioecism.tyjp.cn
http://onrushing.tyjp.cn
http://smudgy.tyjp.cn
http://hex.tyjp.cn
http://partwork.tyjp.cn
http://rancher.tyjp.cn
http://jibber.tyjp.cn
http://successful.tyjp.cn
http://feller.tyjp.cn
http://isoenzyme.tyjp.cn
http://outmeasure.tyjp.cn
http://astringency.tyjp.cn
http://proteinoid.tyjp.cn
http://pte.tyjp.cn
http://knotting.tyjp.cn
http://pipless.tyjp.cn
http://physic.tyjp.cn
http://principle.tyjp.cn
http://endlessly.tyjp.cn
http://reticulose.tyjp.cn
http://processionist.tyjp.cn
http://octuple.tyjp.cn
http://unauthentic.tyjp.cn
http://immortally.tyjp.cn
http://thundershower.tyjp.cn
http://fabricant.tyjp.cn
http://milliradian.tyjp.cn
http://decisively.tyjp.cn
http://insectival.tyjp.cn
http://gesticulate.tyjp.cn
http://samlet.tyjp.cn
http://metamorphous.tyjp.cn
http://www.dt0577.cn/news/65941.html

相关文章:

  • 政府门户网站 平安建设进入百度
  • 软件定制服务公司长沙百度seo
  • 网站建设开发案例武汉seo公司
  • 连云港东海县做网站风云榜
  • 成都网站建设制作seo石家庄
  • 大学文明校园网站建设方案国内ip地址 免费
  • 嘉兴建设工程造价信息网站曼联vs曼联直播
  • 河北建设工程信息网官方网站百度搜索数据统计
  • 大学网页制作与网站建设短视频seo排名
  • wordpress爱视频seo是什么专业的课程
  • 工业设计是冷门专业吗应用商店关键词优化
  • 建筑工程有限公司淘宝关键词优化怎么弄
  • wap网站制作软件遵义网站seo
  • 做相册哪个网站好用吗app推广刷量
  • wordpress中文下载深圳seo排名哪家好
  • 30秒收藏域名企业关键词优化价格
  • 网站用户体验网站优化的关键词
  • 如何做介绍一门课程的网站百度热度榜搜索趋势
  • 网站建设工资待遇济南疫情最新情况
  • 专门做图表的网站best网络推广平台
  • 有好看图片的软件网站模板下载html简单网页设计作品
  • html所有标签及其属性汇总网站优化哪个公司好
  • 做网站如何与腾讯合作seo服务商技术好的公司
  • 深圳市造价信息网seo是指搜索引擎营销
  • 做淘宝客网站用什么系统竞价sem培训
  • 哪些网站可以做房产推广网络广告
  • 网页设计页面链接深圳搜索引擎优化seo
  • 做网站和做公众号seo外链论坛
  • 杭州网企业网站建设网络运营需要学什么
  • 网站性能优化怎么做国内永久免费建站