- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的 THREE.Points
对象有以下设置:
this.particleGeometry = new THREE.BufferGeometry()
this.particleMaterial = new THREE.ShaderMaterial(
{
vertexShader: vshader,
fragmentShader: fshader,
blending: THREE.AdditiveBlending,
depthWrite: false,
uniforms: {
uTime: new THREE.Uniform(0),
uMousePosition: this.mousePosition
}
}
)
然后是一些代码,用于在球体上的 BufferGeometry
中放置点。一切正常。
我还设置了一个 Raycaster 来跟踪与隐藏平面相交的鼠标位置,然后相应地更新统一的 uMousePosition
。这也很好,我将鼠标位置发送到我的顶点着色器。
现在我试图让距离 d
与鼠标有一定距离的粒子从它推开,当然最接近的粒子被推开,并且还向它们施加重力时间后恢复一切的原位。
所以这是我的顶点着色器中的内容:
void main() {
float lerp(float a, float b, float amount) {
return a + (b - a) * amount;
}
void main() {
vec3 p = position;
float dist = min(distance(p, mousePosition), 1.);
float lerpFactor = .2;
p.x = lerp(p.x, position.x * dist, lerpFactor);
p.y = lerp(p.y, position.y * dist, lerpFactor);
p.z = lerp(p.z, position.z * dist, lerpFactor);//Mouse is always in z=0
vec4 mvPosition = modelViewMatrix * vec4(p, 1.);
gl_PointSize = 30. * (1. / -mvPosition.z );
gl_Position = projectionMatrix * mvPosition;
}
}
下面是当鼠标在球体外面时的样子(添加了一个随鼠标位置移动的小球体以指示鼠标位置)
当鼠标在里面时:
外面看起来已经有点正确了,但是鼠标在里面只会让粒子更靠近它们原来的位置,它应该把它们推到更远的外面。我想我必须以某种方式确定距离的方向。
另外, lerp 方法不进行 lerp,粒子直接跳到它们的位置。
所以我想知道我如何获得与鼠标的正确距离以始终在特定区域移动粒子以及如何为 lerp/重力效果设置动画。
最佳答案
这就是你如何做的第一个近似值:
body{
overflow: hidden;
margin: 0;
}
<script type="module">
import * as THREE from "https://cdn.skypack.dev/three@0.136.0";
import {OrbitControls} from "https://cdn.skypack.dev/three@0.136.0/examples/jsm/controls/OrbitControls.js";
import * as BufferGeometryUtils from "https://cdn.skypack.dev/three@0.136.0/examples/jsm/utils/BufferGeometryUtils.js";
let scene = new THREE.Scene();
let camera = new THREE.PerspectiveCamera(60, innerWidth / innerHeight, 1, 100);
camera.position.set(0, 0, 10);
let renderer = new THREE.WebGLRenderer();
renderer.setSize(innerWidth, innerHeight);
document.body.appendChild(renderer.domElement);
let controls = new OrbitControls(camera, renderer.domElement);
let marker = new THREE.Mesh(new THREE.SphereGeometry(0.5, 16, 8), new THREE.MeshBasicMaterial({color: "red", wireframe: true}));
scene.add(marker);
let g = new THREE.IcosahedronGeometry(4, 20);
g = BufferGeometryUtils.mergeVertices(g);
let uniforms = {
mousePos: {value: new THREE.Vector3()}
}
let m = new THREE.PointsMaterial({
size: 0.1,
onBeforeCompile: shader => {
shader.uniforms.mousePos = uniforms.mousePos;
shader.vertexShader = `
uniform vec3 mousePos;
${shader.vertexShader}
`.replace(
`#include <begin_vertex>`,
`#include <begin_vertex>
vec3 seg = position - mousePos;
vec3 dir = normalize(seg);
float dist = length(seg);
if (dist < 2.){
float force = clamp(1. / (dist * dist), 0., 1.);
transformed += dir * force;
}
`
);
console.log(shader.vertexShader);
}
});
let p = new THREE.Points(g, m);
scene.add(p);
let clock = new THREE.Clock();
renderer.setAnimationLoop( _ => {
let t = clock.getElapsedTime();
marker.position.x = Math.sin(t * 0.5) * 5;
marker.position.y = Math.cos(t * 0.3) * 5;
uniforms.mousePos.value.copy(marker.position);
renderer.render(scene, camera);
})
</script>
关于three.js - 将粒子推离glsl和三个js中的mouseposition,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66136122/
我正在为 Openlayers 3 提供的 MousePosition 设置样式。但是,这个问题与此 MousePosition 的行为有关。 我想实现的是: 将 MousePosition 插入 c
当光标位于红十字(元素的绝对中间)上时,我尝试将左上角所示的坐标设置为 0% 和 0%。向左移动应该使 X 轴变为负值。当我上升时,Y 轴也是如此。向右/向下应该包含正值。 正如您在图像中看到的,坐标
我尝试为矢量图开发交互式查看器,并希望具有缩放功能。缩放功能效果很好,但现在我在计算拾取对象的鼠标位置时遇到了问题。该事件返回屏幕坐标。 Canvas 没有以相反方式使用变换矩阵的方法。有人能解决这个
我想在鼠标位置打开 JQuery UI 对话框。我的代码有什么问题? $(document).ready(function () { var x; var y
我有一个 NSTextView 子类作为 NSSplitViewController 中的右侧项目,左侧面板是一个 NSOutlineView。为了在 TextView 中按下命令键时处理鼠标单击
我在 GridControl 上有一个 MouseDown 事件,用于确定用户单击了哪一行: private void genericView_MouseDown(object sender,
我从某个网站复制了这个 PowerShell 代码,它显示了鼠标的当前位置: [Reflection.Assembly]::LoadWithPartialName('System.Windows.Fo
我是一名优秀的程序员,十分优秀!