123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- Component({
- behaviors: [require('../../common/share-behavior').default],
- properties: {
- a: Number,
- },
- data: {
- loaded: false
- },
- lifetimes: {},
- methods: {
- handleReady({detail}) {
- const xrScene = this.scene = detail.value;
- console.log('xr-scene', xrScene);
- },
- handleAssetsProgress: function({detail}) {
- console.log('assets progress', detail.value);
- },
- handleAssetsLoaded: function({detail}) {
- console.log('assets loaded', detail.value);
- this.setData({loaded: true});
-
- setTimeout(()=>{
- this.setUVAnimation();
- },200);
- },
- setUVAnimation() {
- const scene = this.scene;
- const xrSystem = wx.getXrFrameSystem();
-
- const twaElm = this.scene.getElementById('twa');
- const twaGLTF = twaElm.getComponent(xrSystem.GLTF);
-
- const changeMesh = twaGLTF.getPrimitivesByNodeName('Cube_0')[0];
- const changeMaterial = changeMesh.material;
- let offsetX = 0;
- let offsetY = 0;
- let scaleX = 1;
- let scaleY = 1;
- let rotation = 0;
-
- setInterval(()=>{
-
- offsetX = offsetX > 1 ? 0 : offsetX + 0.01;
- offsetY = offsetY > 1 ? 0 : offsetY + 0.01;
-
-
-
-
-
- const uvMatrix = xrSystem.Matrix4.createFromArray(this.getUvTransform(offsetX, offsetY, scaleX, scaleY, rotation))
-
- changeMaterial.setMatrix('u_uvTransform', uvMatrix);
- }, 40);
- const uvMatrix = xrSystem.Matrix4.createFromArray(this.getUvTransform(offsetX, offsetY, scaleX, scaleY, rotation))
-
- changeMaterial.setMatrix('u_uvTransform', uvMatrix);
-
- changeMaterial.setMacro('WX_USE_UVTRANSFORM', true );
- changeMaterial.setMacro('WX_USE_UVTRANSFORM_BASECOLOR', true );
- }
- ,
-
- getUvTransform(tx, ty, sx, sy, rotation) {
- const c = Math.cos( rotation );
- const s = Math.sin( rotation );
- return [
- sx * c, -sx * s, 0, 0,
- sy * s, sy * c, 0, 0,
- 0, 0, 1, 0,
- tx, ty, 0, 1,
- ];
- }
- }
- })
|