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

想做个网络推广昆明网站建设方案优化

想做个网络推广,昆明网站建设方案优化,优质网站建设方案,浙江网站备案1 实现思路 绘制单个点鼠标事件监听点击事件将点推送到数组中绘制数组中所有点 2 实现代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge&…

1 实现思路

  • 绘制单个点
  • 鼠标事件监听点击事件
  • 将点推送到数组中
  • 绘制数组中所有点

2 实现代码

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="js/glMatrix-0.9.6.min.js"></script><script>let vertexstring = `attribute vec3 a_position;uniform     mat4    proj;void main(void){gl_Position = vec4(a_position,1.0)  ;gl_PointSize=60.0;}`;let fragmentstring = `precision mediump float;void main(void){gl_FragColor = vec4(0.0,0.0,1.0,1.0);}`;var projMat4 = mat4.create();var webgl;function init() {initWebgl();initShader();initBuffer();draw();}function initWebgl() {let webglDiv = document.getElementById('myCanvas');webgl = webglDiv.getContext("webgl");webgl.viewport(0, 0, webglDiv.clientWidth, webglDiv.clientHeight);mat4.ortho(0, webglDiv.clientWidth, webglDiv.clientHeight, 0, -1.0, 1.0, projMat4)}function initShader() {let vsshader = webgl.createShader(webgl.VERTEX_SHADER);let fsshader = webgl.createShader(webgl.FRAGMENT_SHADER);webgl.shaderSource(vsshader, vertexstring);webgl.shaderSource(fsshader, fragmentstring);webgl.compileShader(vsshader);webgl.compileShader(fsshader);if (!webgl.getShaderParameter(vsshader, webgl.COMPILE_STATUS)) {var err = webgl.getShaderInfoLog(vsshader);alert(err);return;}if (!webgl.getShaderParameter(fsshader, webgl.COMPILE_STATUS)) {var err = webgl.getShaderInfoLog(fsshader);alert(err);return;}let program = webgl.createProgram();webgl.attachShader(program, vsshader);webgl.attachShader(program, fsshader)webgl.linkProgram(program);webgl.useProgram(program);webgl.program = program}var points = [];var colors=[];function initBuffer() {let aPsotion = webgl.getAttribLocation(webgl.program, "a_position");document.addEventListener("mousedown", function (e) {debuggerlet x = e.clientX;let y = e.clientY;let rect = e.target.getBoundingClientRect();let pointx = ((x - rect.left) - 512) / 512;//let pointy = -((y - rect.top) - 350) / 350;let pointy = (350 - (y - rect.top)) / 350;points.push(pointx);points.push(pointy);points.push(0);let pointPosition = new Float32Array(points);//创建缓冲区let pointBuffer = webgl.createBuffer();webgl.bindBuffer(webgl.ARRAY_BUFFER, pointBuffer);webgl.bufferData(webgl.ARRAY_BUFFER, pointPosition, webgl.STATIC_DRAW);webgl.enableVertexAttribArray(aPsotion);webgl.vertexAttribPointer(aPsotion, 3, webgl.FLOAT, false, 0, 0);webgl.clearColor(0.0, 0.0, 0.0, 1.0);webgl.clear(webgl.COLOR_BUFFER_BIT | webgl.DEPTH_BUFFER_BIT);webgl.drawArrays(webgl.POINTS, 0, points.length / 3);})let uniformProj = webgl.getUniformLocation(webgl.program, "proj");webgl.uniformMatrix4fv(uniformProj, false, projMat4);}function draw() {webgl.clearColor(0.0, 0.0, 0.0, 1.0);webgl.clear(webgl.COLOR_BUFFER_BIT | webgl.DEPTH_BUFFER_BIT);}</script>
</head><body onload="init()"><canvas id='myCanvas' width="1024" height='700'></canvas>
</body></html>

3 实现效果

鼠标点击加载图像

http://www.yayakq.cn/news/814721/

相关文章:

  • 莆田自助建站软件大网站设计
  • 网站建设如何存数据wordpress内容清空
  • 网站推广合同需要缴纳印花税吗优享微信网站建设
  • 大数据做网站流量分析html5编程入门自学
  • 关于建设门户网站的通知下载网页上的视频
  • 网站建设及推广服务的合同范本网站不备案可以么
  • 百度网站怎么做的赚钱小程序外包开发多少钱
  • 深圳专业专业网站设计大访问量的网站怎么做优化
  • 网站建设额互联网备案查询
  • 建设厅网站查询电工证件哈尔滨网站建设公司
  • 福清市建设工程交易网站好像1元1年xyz域名
  • 关于旅游网站开发的研究方法郑州网站建设技术方案
  • 微网站建设方案百度关键词排名价格
  • 网站建设项目的工作分解appcan 手机网站开发
  • 廊坊专业网站制作服务建设征婚网站
  • 网站上线前做环境部署图片拼接做网站背景
  • 怎么看网站点击量手机软件商城
  • 莘县住房建设局网站网站开发中的qq登录
  • 青岛知名网站建设公司帮别人做买家秀的网站
  • 网站编辑工作好做吗单位网站备案流程
  • 允许个人做动漫网站吗雅布设计公司
  • 公司网站页面加密黄骅港邮编号是多少
  • 网站优化费用怎么做会计分录宿迁房产网58同城网二手房
  • 用心做的网站wordpress怎么做采集
  • 一次性付费做网站购物网站建设策划
  • 2019做网站必须做可信网站吗福州网站建设金森
  • 莱芜租房网站企业网站程序源码
  • 怎么制作微信购物网站网站的好坏
  • 杭州建设网站公司网站哈尔滨网站建设步骤
  • 怎么做网站淘宝转换工具绍兴seo整站优化