const vertexShaderSource = ` attribute vec2 a_position; varying vec2 v_texCoord; void main(void) { gl_Position = vec4(a_position, 0.0, 1.0); v_texCoord = (a_position + 1.0) / 2.0; // 将坐标从[-1,1]映射到[0,1] }`; // 适宜度着色器 const fragmentShaderSuitable = ` precision mediump float; varying vec2 v_texCoord; uniform sampler2D u_texture; void main(void) { vec4 color = texture2D(u_texture, vec2(v_texCoord.x, 1.0 - v_texCoord.y)); if (color.g > 0.0 || color.b > 0.0 || color.a > 0.0) { float value = (color.g * 255.0*255.0 + color.b*255.0) / 10.0; if (value >= -15.0 && value <= 15.0) { // 次适宜 color = vec4(255.0/255.0,166.0/255.0,210.0/255.0,1.0); } else if (value > 15.0 && value <= 30.0) { // 适宜 color = vec4(132.0/255.0,255.0/255.0,132.0/255.0, 1.0); } else { // 不适宜 color = vec4(255.0 / 255.0, 0.0, 0.0, 1.0); } } else { color = vec4(1.0, 0.0, 0.0, 0); } gl_FragColor = color; }`;
在vue data外声明
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· AI与.NET技术实操系列(六):基于图像分类模型对图像进行分类