2017-08-08 9 views
1

Lee Stemkoskiさんのexampleに続いて、フレームに屈折球を設定しようとしています。私は反射球を得ることに成功しました。これは、基本的には冷たいもののストリップですa-frame mirror componentThreeCubeCameraを使用した屈折

CubeCameraが作成され、そのレンダーターゲットが初期化時に環境マップテクスチャとして抽出されます
INIT:

this.refractionCamera = new THREE.CubeCamera(0.5, 3000, 128); 
this.el.object3D.add(this.refractionCamera); 
this.refractionMaterial = new THREE.MeshBasicMaterial({ 
     color: 0xffffff, 
     refractionRatio: 0.4, 
     envMap: this.refractionCamera.renderTarget.texture }); 

更新ダニのキューブマップ:
ダニ:

this.refractionCamera.updateCubeMap(AFRAME.scenes[0].renderer,       
this.el.sceneEl.object3D); 
this.mesh.material = this.refractionMaterial; 

もちろん、画像はどのようにThree.CubeCameraを使用するかによってミラーリングされます私は鏡を持っていないので、テクスチャを回転させるか、何とかそれを反転しようとしました。

私はリーStemkoskiのみを使用している見ての通り:

refractSphereCamera.renderTarget.mapping = new THREE.CubeRefractionMapping(); 
  • 私はinitのことをやってみましたが、何も変わりません。 fiddleをご覧ください。

  • また、テクスチャのオフセット、または垂直反転を試しましたが、何もないhappens

私のアプローチで何が間違っていますか?

+0

屈折を望むなら、 'this.refractionCamera.renderTarget.texture.mapping = THREE.Cub eRefractionMapping; '? – prisoner849

+0

@ prisoner849私はちょっとそれを達成しようとしている最初の詐欺:https://jsfiddle.net/ncspy8x2/1/、または何か別の意味ですか? –

答えて

1

あなたが屈折したい場合は、それが

refractSphereCamera.renderTarget.texture.mapping = THREE.CubeRefractionMapping; 

jsfiddle例を実行するために、より良い

refractSphereCamera.renderTarget.mapping = THREE.CubeRefractionMapping; 

だん

+0

どうもありがとうございました。 –

+0

@PiotrAdamMilewskiよろしくお願いします。 「new」キーワードを指してくれてありがとう)私は答えでそれを見落としてしまった) – prisoner849

+1

問題なし、ちょうど将来の混乱を避けたかった:)、もう一度ありがとう! –

1

Lee Stemkoskiの例は、古いバージョンのThree.jsで4年前に作成されたものです。彼のソースコードはDate: July 2013 (three.js v59dev)ですが、あなたのフィドルはv84を使っています。

this exampleはThree.jsの最新バージョンと互換性があります。あなたがソースコードを見れば、実装は今はるかに簡単です:

// Load textureCube, change mapping from reflection to refraction 
var textureCube = new THREE.CubeTextureLoader().load(urls); 
textureCube.mapping = THREE.CubeRefractionMapping; 

// Assign textureCube to background 
scene = new THREE.Scene(); 
scene.background = textureCube; 

// Use textureCube as environment map, which will use refraction mapping. 
var cubeMaterial3 = new THREE.MeshPhongMaterial({ color: 0xccddff, envMap: textureCube, refractionRatio: 0.98, reflectivity: 0.9 }); 
+2

あなたのサンプルコードを更新して、OPCが助けを求めている具体的なものであるように、CubeCameraのレンダリングをURLではなくtextureCubeのイメージとして使用することができます。また、コンソールに表示されているように、この例はr60 of three.jsです。 – 2pha

+0

1.私は、Lee Stemkoskiの例が古いバージョンであることを認識しているので、(新しい)Three.CubeRefractionMapping()の代わりにmapping = Three.CubeRefractonMappingを使用しました。私も知っている、私はより効率的な6つのカメラを更新し、そこからenvMapテクスチャを作成するenvMapのテクスチャの屈折を行うことができます知っている。 3.もしあなたが私のCubeCameraでtextureCubeを置き換えるならば。renderTargetではなく、renderTarget.textureではなく、renderTargetのマッピングをやろうとしていたのですが、それは私の最初の試行(最初のフィドル)と同じようです。 –

関連する問題