mirror of
https://github.com/troisjs/trois.git
synced 2024-11-24 04:12:02 +08:00
add RectAreaLight
This commit is contained in:
parent
c477a8cfb3
commit
42386a572d
27
src/lights/RectAreaLight.js
Normal file
27
src/lights/RectAreaLight.js
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
import { RectAreaLight } from 'three';
|
||||||
|
import { RectAreaLightUniformsLib } from 'three/examples/jsm/lights/RectAreaLightUniformsLib.js';
|
||||||
|
import { RectAreaLightHelper } from 'three/examples/jsm/helpers/RectAreaLightHelper.js';
|
||||||
|
import { watch } from 'vue';
|
||||||
|
import Light from './Light.js';
|
||||||
|
|
||||||
|
export default {
|
||||||
|
extends: Light,
|
||||||
|
props: {
|
||||||
|
width: { type: Number, default: 10 },
|
||||||
|
height: { type: Number, default: 10 },
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
RectAreaLightUniformsLib.init();
|
||||||
|
this.light = new RectAreaLight(this.color, this.intensity, this.width, this.height);
|
||||||
|
|
||||||
|
['width', 'height'].forEach(p => {
|
||||||
|
watch(() => this[p], () => {
|
||||||
|
this.light[p] = this[p];
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
this.$parent.add(new RectAreaLightHelper(this.light));
|
||||||
|
this.initLight();
|
||||||
|
},
|
||||||
|
__hmrId: 'RectAreaLight',
|
||||||
|
};
|
@ -1,4 +1,5 @@
|
|||||||
export { default as AmbientLight } from './AmbientLight.js';
|
export { default as AmbientLight } from './AmbientLight.js';
|
||||||
export { default as DirectionalLight } from './DirectionalLight.js';
|
export { default as DirectionalLight } from './DirectionalLight.js';
|
||||||
export { default as PointLight } from './PointLight.js';
|
export { default as PointLight } from './PointLight.js';
|
||||||
|
export { default as RectAreaLight } from './RectAreaLight.js';
|
||||||
export { default as SpotLight } from './SpotLight.js';
|
export { default as SpotLight } from './SpotLight.js';
|
||||||
|
@ -30,6 +30,7 @@ export const TroisJSVuePlugin = {
|
|||||||
'AmbientLight',
|
'AmbientLight',
|
||||||
'DirectionalLight',
|
'DirectionalLight',
|
||||||
'PointLight',
|
'PointLight',
|
||||||
|
'RectAreaLight',
|
||||||
'SpotLight',
|
'SpotLight',
|
||||||
|
|
||||||
'BasicMaterial',
|
'BasicMaterial',
|
||||||
|
Loading…
Reference in New Issue
Block a user