首页 > 其他分享 >three.js 入门学习(一)

three.js 入门学习(一)

时间:2023-05-03 16:46:17浏览次数:45  
标签:scene const 入门 THREE three camera renderer new js

webGl和three.js

http://webgl3d.cn/pages/aac9ab/

图形学算法

Web3D

WebGPU

下载

yarn add three @types/three

使用

import * as THREE from 'three';

onst scene = new THREE.Scene();
仅导入你所需要的部分

import { Scene } from 'three';

一个初始化的demo

场景、相机和渲染器, 设置大小, 添加到页面上

const scene = new THREE.Scene();
const camera = new THREE.PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 0.1, 1000 );

const renderer = new THREE.WebGLRenderer();
renderer.setSize( window.innerWidth, window.innerHeight );
document.body.appendChild( renderer.domElement );

添加一个立方体, 设置样式, 网格对象放入到我们的场景中, 物体将会添加到坐标中, 设置层级

const geometry = new THREE.BoxGeometry( 1, 1, 1 );
const material = new THREE.MeshBasicMaterial( { color: 0x00ff00 } );
const cube = new THREE.Mesh( geometry, material );
scene.add( cube );

camera.position.z = 5;

循环场景, 添加

function animate() {
	requestAnimationFrame( animate );
	renderer.render( scene, camera );
}
animate();

让立方体动起来(添加到animate()函数中renderer.render调用的上方)

cube.rotation.x += 0.01;
cube.rotation.y += 0.01;

https://github.com/pmndrs/postprocessing

后期

WebGLRenderer

渲染器

场景Scene相机Camera渲染器Renderer



        var renderer: THREE.WebGLRenderer, scene: THREE.Scene | THREE.Object3D<THREE.Event>, camera: any, composer,
            circle: THREE.Object3D<THREE.Event>, skelet: any, particle: THREE.Object3D<THREE.Event>;

        window.onload = function () {
            init();
            animate();
            // 设置相机控件轨道控制器OrbitControls
            const controls = new OrbitControls(camera, renderer.domElement);
// 如果OrbitControls改变了相机参数,重新调用渲染器渲染三维场景
            controls.addEventListener('change', function () {
                renderer.render(scene, camera); //执行渲染操作
            });//监听鼠标、键盘事件
        }

        function init() {
            // antialias - 是否执行抗锯齿。默认为false.
            // alpha 默认为false 颜色透明度
            renderer = new THREE.WebGLRenderer({antialias: true, alpha: true});
            // 设置设备像素比
            // window.devicePixelRatio是设备上物理像素和设备独立像素,
            // 公式表示就是:window.devicePixelRatio = 物理像素 / dips
            // dip或dp 与屏幕密度有关。dip可以用来辅助区分视网膜设备还是非视网膜设备。
            renderer.setPixelRatio((window.devicePixelRatio) ? window.devicePixelRatio : 1);
            // 设置大小
            renderer.setSize(window.innerWidth, window.innerHeight);
            renderer.autoClear = false;
            // 设置颜色及其透明度
            renderer.setClearColor(0x000000, 0.0);
            // 把渲染器的dom添加到页面上
            (document.getElementById('canvas') as any).appendChild(renderer.domElement);
            // 场景
            scene = new THREE.Scene();
            // 相机
            /*
            * fov — 摄像机视锥体垂直视野角度
              aspect — 摄像机视锥体长宽比
              near — 摄像机视锥体近端面
              far — 摄像机视锥体远端面
            * */
            camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 1, 1000);
            // 设置相机的位置
            camera.position.z = 400;
            // 把相机添加到场景中
            scene.add(camera);
            // 圆
            circle = new THREE.Object3D();
            skelet = new THREE.Object3D();
            // 基类, 提供一些属性和方法来对三维空间中的物体进行操纵
            particle = new THREE.Object3D();

            scene.add(circle);
            scene.add(skelet);
            scene.add(particle);
            // 四面缓冲几何体
            var geometry = new THREE.TetrahedronGeometry(2, 0);
            // 二十面缓冲几何体
            // 二十面体的半径,默认为1。
            //  默认值为0。将这个值设为一个大于0的数将会为它增加一些顶点,使其不再是一个二十面体。当这个值大于1的时候,实际上它将变成一个球体。
            var geom = new THREE.IcosahedronGeometry(7, 1);
            // 半径大一些
            var geom2 = new THREE.IcosahedronGeometry(15, 1);
            // 材质, 受高光影响的材质
            var material = new THREE.MeshPhongMaterial({
                color: 0xffffff,
                flatShading: true // 定义材质是否使用平面着色进行渲染
            });

            for (var i = 0; i < 1000; i++) {
                // 网格模型, 一个几何体, 一个材质
                var mesh = new THREE.Mesh(geometry, material);
                // 随机设置位置
                mesh.position.set(Math.random() - 0.5, Math.random() - 0.5, Math.random() - 0.5).normalize();
                // 将该向量与所传入的标量s进行相乘
                mesh.position.multiplyScalar(70 + (Math.random() * 700));
                //设置旋转角度
                mesh.rotation.set(Math.random() * 2, Math.random() * 2, Math.random() * 2);
                // 把物体添加到基类中, 也可以直接添加到scene 中
                particle.add(mesh);
            }

            var mat = new THREE.MeshPhongMaterial({
                color: 0xffffff,
                flatShading: true
            });

            var mat2 = new THREE.MeshPhongMaterial({
                color: 0xffffff,
                wireframe: true,// 这个是设置骨架
                side: THREE.DoubleSide

            });
            // 这个 是小的
            var planet = new THREE.Mesh(geom, mat);
            // 小多面体放大的倍数
            planet.scale.x = planet.scale.y = planet.scale.z = 16;
            circle.add(planet);
            // 这个是大的骨架
            var planet2 = new THREE.Mesh(geom2, mat2);
            // 大多面体放大的倍数
            planet2.scale.x = planet2.scale.y = planet2.scale.z = 10;
            skelet.add(planet2);
            // 环境光
            var ambientLight = new THREE.AmbientLight(0x999999);
            scene.add(ambientLight);

            var lights = [];
            // 加入三个不同平行光, 展示不同的颜色
            // 平行光
            lights[0] = new THREE.DirectionalLight(0xffffff, 1);
            // 位置
            lights[0].position.set(1, 0, 0);
            lights[1] = new THREE.DirectionalLight(0x11E8BB, 1);
            lights[1].position.set(0.75, 1, 0.5);
            lights[2] = new THREE.DirectionalLight(0x8200C9, 1);
            lights[2].position.set(-0.75, -1, 0.5);
            scene.add(lights[0]);
            scene.add(lights[1]);
            scene.add(lights[2]);


            window.addEventListener('resize', onWindowResize, false);

        };

        function onWindowResize() {
            // 设置相机的长宽比
            camera.aspect = window.innerWidth / window.innerHeight;
            // 更新摄像机投影矩阵。在任何参数被改变以后必须被调用。
            camera.updateProjectionMatrix();
            renderer.setSize(window.innerWidth-100, window.innerHeight-100);
        }

        function animate() {
            requestAnimationFrame(animate);
            // 设置三个网格体的旋转数据
            particle.rotation.x += 0.0000;
            particle.rotation.y -= 0.0040;
            circle.rotation.x -= 0.0020;
            circle.rotation.y -= 0.0030;
            skelet.rotation.x -= 0.0010;
            skelet.rotation.y += 0.0020;
            // 渲染器清除颜色、深度或模板缓存
            renderer.clear();
            renderer.render(scene, camera)
        }

outputEncoding

outputEncoding属性控制输出渲染编码。默认情况下,outputEncoding的值为THREE.LinearEncoding,看起来还行但是不真实,建议将值改为`THREE.sRGBEncoding

圆环缓冲扭结几何体

        const canvas: any = document.getElementById("canvas");
        let camera: any, scene: any, renderer: any, controls: any;
        let geometry, material, mesh: any;

        let ww, hh;
        const size = 3;

        ww = document.body.clientWidth / 2 / window.devicePixelRatio;
        hh = ww;
        // 场景
        scene = new THREE.Scene();
        // 渲染器
        renderer = new THREE.WebGLRenderer({
            antialias: true,//抗锯齿
            alpha: true // 是否透明
        });
        // 把渲染器的dom添加到页面上
        (document.getElementById('canvas') as any).appendChild(renderer.domElement);
        // // 设置设备像素比
        renderer.setPixelRatio(window.devicePixelRatio);
        // 设置大小
        renderer.setSize(ww, hh, false);
        // outputEncoding默认是LinearEncoding看起来还行但是不真实,可以设置为sRGBEncoding 会更自然
        renderer.outputEncoding = THREE.sRGBEncoding;
        // 摄像机
        camera = new THREE.PerspectiveCamera(40, ww / hh, 0.01, size * 30);
        // 设置摄像机的位置
        camera.position.set(0, size, size * 6);
        // 设置网格模型对象的坐标原点
        camera.lookAt(0, 0, 0);

        // 环境光
        const light = new THREE.AmbientLight(0x2980B9, 0.5);
        scene.add(light);

        // 平行光, 第二个参数光的强度
        const directionalLight = new THREE.DirectionalLight(0xF8C471, 0.8);
        directionalLight.position.set(0, size * 6, size * 5);
        // 模拟场景中平行光 DirectionalLight 的辅助对象
        const helper = new THREE.DirectionalLightHelper(directionalLight, 2, 0x239B56);
        scene.add(helper);
        scene.add(directionalLight);

        // 几何体---- 圆环缓冲扭结几何体
        /*
    * radius - 圆环的半径,默认值为1。
        tube — 管道的半径,默认值为0.4。
        tubularSegments — 管道的分段数量,默认值为64。
        radialSegments — 横截面分段数量,默认值为8。
        p — 这个值决定了几何体将绕着其旋转对称轴旋转多少次,默认值是2。
        q — 这个值决定了几何体将绕着其内部圆环旋转多少次,默认值是3。
    * */
        geometry = new THREE.TorusKnotGeometry(size, size / 3, 100, 16);
        // 一种基于物理的标准材质
        material = new THREE.MeshStandardMaterial({
            color: new THREE.Color("#FF7F50"),
            roughness: 0 // 材质的粗糙程度。0.0表示平滑的镜面反射,1.0表示完全漫反射。默认值为1.0。
        });
        // 几何体和材质变成网格模型
        mesh = new THREE.Mesh(geometry, material);
        scene.add(mesh);

        //轨道控制器--- 可以使得相机围绕目标进行轨道运动
        controls = new OrbitControls(camera, renderer.domElement);
        // 将其设为true,以自动围绕目标旋转
        controls.autoRotate = false;
        //阻尼惯性有多大。 Default is 0.05
        controls.enableDamping = true;
        // 启用或禁用摄像机平移,默认为true。
        controls.enablePan = false;
        // 相机向内移动多少
        controls.minDistance = size * 5.5;
        // 将相机向外移动多少
        controls.maxDistance = size * 10;
        controls.target.set(0, 0, 0);
        controls.update();

        window.addEventListener("resize", () => {
            ww = document.body.clientWidth / 2 / window.devicePixelRatio;
            hh = ww;
            camera.aspect = ww / hh;
            camera.updateProjectionMatrix();
            renderer.setSize(ww, hh, false);
        }, false);

        animate();
        function animate() {
            requestAnimationFrame(animate);
            controls.update();
            mesh.rotation.x += 0.01;
            mesh.rotation.z -= 0.01;
            renderer.render(scene, camera);
        }

指导几个概练

场景Scene相机Camera渲染器Renderer

写一个带箭头的辅助线

        const dir = new THREE.Vector3(-2.49, 4.74, -3.01).normalize();
        const origin = new THREE.Vector3(0, 0, 0);
        const length = 10;
        const hex = 0xffff00;
        const arrowHelper = new THREE.ArrowHelper(dir, origin, length, hex);
        scene.add(arrowHelper)

让天球以北极星为中心旋转

  // 向量
        const dir = new THREE.Vector3(-2.49, 4.74, -3.01).normalize();
        // 建立四元数
        const quaternion = new THREE.Quaternion();
        let rotation1 = 0;
        // 由dir 为轴心, rotation 为旋转弧度
        quaternion.setFromAxisAngle(dir, rotation1);

        function animate(){
            // 不断增加弧度
            rotation1 += 0.01;
            // // 更新四元数
            quaternion.setFromAxisAngle(dir, rotation1);
            // // 增加的弧度更新到我们的天球上
            sphere.rotation.setFromQuaternion(quaternion);
            requestAnimationFrame(animate);
            renderer.render(scene, camera);
        }

Control

围绕中心点的控制镜头方式

控制镜头的方式有:

  • OrbitControls

    轨道控制, 最常用, 你的镜头在一个隐形的圆形的轨道中移动,它永远面向场景中的一个点。预设原点。

  • ArcballControls

    弧球控制,比轨道控制难用一点的控制,差在可以360度旋转镜头,使得你的镜头水平不平衡。

  • DragControls

    用来拖拽场景中的物体,镜头不会移动

  • FirstPersonControls & FlyControls & PointerLockControls

    第一人称视角,没有轨道概念

  • TrackballControls

    OrbitControls 很像, 可是当用户把镜头绕过最顶端之后, 并不会绕过头,而TrackballControls 则会,

  • TransformControls

    主要是作为控制物体, 而非控制镜头的

OrbitControls

它会操控你的镜头

你会修改自己的镜头位置,它也会。控制镜头为至的方式就是修改Camera.position

OrbitControl.target:镜头所看向的目标物件,是一个位置资讯Vecro3

OrbitControl不會在每幀渲染時自動控制,得用OrbitControl.update()更新。

圆形轨道的镜头轨道

      const scene = new THREE.Scene();
        const camera = new THREE.PerspectiveCamera(50, window.innerWidth / window.innerHeight, 0.1, 1000);
       // 设置镜头位置
        camera.position.set(0, 10, 15);
        // 渲染器
        const renderer = new THREE.WebGLRenderer();
        renderer.setSize(window.innerWidth, window.innerHeight);
        document.body.appendChild(renderer.domElement);

        const geometry = new THREE.SphereGeometry(100, 50, 50);
        // 加载材质
        const texture = new THREE.TextureLoader().load('https://storage.googleapis.com/umas_public_assets/michaelBay/free_star_sky_hdri_spherical_map_by_kirriaa_dbw8p0w%20(1).jpg');
        // 物理的标准材质
        const material=new THREE.MeshStandardMaterial({map:texture, side: THREE.DoubleSide})
        // 环境光
        const light = new THREE.AmbientLight(0xffffff, 1);
        scene.add(light);
        // 星空
        const sphere = new THREE.Mesh(geometry, material);
        scene.add(sphere);

        const earthGeometry = new THREE.SphereGeometry(5, 50, 50);
        // 载入材质
        const earthTexture = new THREE.TextureLoader().load('https://storage.googleapis.com/umas_public_assets/michaelBay/1280px-Solarsystemscope_texture_8k_earth_daymap.jpeg')
        const earthMaterial = new THREE.MeshStandardMaterial( { map: earthTexture, side: THREE.DoubleSide})
        // 地球
        const earth = new THREE.Mesh(earthGeometry, earthMaterial);
        scene.add(earth);
        // 控制镜头
        const control = new OrbitControls( camera, renderer.domElement );

        const axesHelper = new THREE.AxesHelper( 5 );
        scene.add( axesHelper );

        // 修改镜头的方式, 修改位置,让他镜头轨道更真实
        control.target.set(10, 0, 0);
        control.update();
        function animate() {
            requestAnimationFrame( animate );
            renderer.render( scene, camera );

        }
        animate();

总结: target 跟 lookAt 的差异

使用orbitControl.target = car.position.clone() 就能移动中心点

向量

.lerp()

改成百分比的向量使用

  	    const v1 = new THREE.Vector3(0, 0, 0);
        const v2 = new THREE.Vector3(10, 10, 10);
        const a = v1.lerp(v2, 0.25);
        console.log(a);
        // Vector3 {x: 2.5, y: 2.5, z: 2.5}

.add ( v : Vector3 )

两个向量想加

    	const v1 = new THREE.Vector3(20, 20, 20);
        const v2 = new THREE.Vector3(10, 10, 10);
        console.log(v1.add(v2));
        // Vector3 {x: 30, y: 30, z: 30}

.addScalar ( s : Float )

将传入的标量s和这个向量的x值、y值以及z值相加。

        const v1 = new THREE.Vector3(20, 20, 20);
        console.log(v1.addScalar(20));
        // Vector3 {x: 40, y: 40, z: 40}

.addScaledVector ( v : Vector3, s : Float )

将所传入的v与s相乘所得的乘积和这个向量相加。

const v2 = new THREE.Vector3(10, 10, 10);
const v1 = new THREE.Vector3(20, 20, 20);
console.log(v1.addScaledVector(v2, 2));
// v2 * 2 +v1
Vector3 {x: 40, y: 40, z: 40}

.addVectors ( a : Vector3, b : Vector3 ) : this

将该向量设置为a + b

 		const v2 = new THREE.Vector3(10, 10, 10);
        const v1 = new THREE.Vector3(20, 20, 20);
        const v3 = new THREE.Vector3();
        v3.addVectors(v1, v2);
		v3
        //  Vector3 {x: 30, y: 30, z: 30}

向量归一化

向量归一化常用于进行移动和方向计算,通过归一化向量可以得到一个方向向量,并用它来对物体进行移动,而不需要关心物体的速度。此外,向量归一化还可以用于实现光线投射、碰撞检测等功能。

.applyAxisAngle ( axis : Vector3, angle : Float ) : this

axis - 一个被归一化的Vector3
angle - 以弧度表示的角度。

将轴和角度所指定的旋转应用到该向量上。

        const v2 = new THREE.Vector3(10, 10, 10).normalize();
        const v1 = new THREE.Vector3(20, 20, 20);
		v1.applyAxisAngle(v2, 1/4*Math.PI)
		以v1的起点, v2 为轴, 然后旋转的角度, 找到新设置的旋转点

.applyEuler ( euler : Euler ) : this

通过将Euler(欧拉)对象转换为Quaternion(四元数)并应用, 将欧拉变换应用到这个向量

欧拉对象Euler

构造函数:Euler(x,y,z,order) 参数xyz分别表示绕xyz轴旋转的角度值,角度单位是弧度。参数order表示旋转顺序,默认值XYZ,也可以设置为YXZYZX等值

// 创建一个欧拉对象,表示绕着xyz轴分别旋转45度,0度,90度
var Euler = new THREE.Euler( Math.PI/4,0, Math.PI/2);

四元数Quaternion

四元数对象Quaternion使用x、y、z和w四个分量表示, 用四元数来处理模型旋转

Euler 类(欧拉角)与角度有关, 而Vector3 与位置有关,在实际使用中,Vector3 可用于设置位置,而 Euler 是设置对象方向的一种方式

       const scene = new THREE.Scene();
        const camera = new THREE.PerspectiveCamera(60, 320 / 240, 0.1, 1000);
        camera.position.set(2, 2, 2);
        camera.lookAt(0, 0, 0);
        const renderer = new THREE.WebGLRenderer();
        renderer.setSize(640, 480, false);
        (document.body).appendChild(renderer.domElement);
        // 欧拉角
        const euler = new THREE.Euler(Math.PI / 180 * 45, 0, 0)
        // 法线网格材质(种把法向量射到RGB颜色的材质)
        const meshA = new THREE.Mesh(new THREE.BoxGeometry(1, 1, 1),
            new THREE.MeshNormalMaterial());
        // 复制三个物体
        const box1 = meshA.clone(),
            box2 = meshA.clone(),
            box3 = meshA.clone();
        // 使用 EULER 的实例来设置状态
        box2.rotation.copy(euler);
        box3.rotation.copy(euler);
        // 设置位置
        box2.position.set(-1, 0, 0);
        box3.position.set(1, 0, 0);
        // 添加到视图上
        scene.add(box1);
        scene.add(box2);
        scene.add(box3);
        // 添加到渲染器上
        renderer.render(scene, camera);

设置环形旋转的效果

 let lt:any = new Date();
        const loop = function () {
            const now: any = new Date(),
                secs: any = (now - lt) / 1000;
            // 计算每秒消耗时间
            requestAnimationFrame(loop);
            if (secs >= 0.075) {
                lt = now;
                // USING EULER XYZ PROPS
                box2.rotation.x += 1 * secs;
                box2.rotation.x %= Math.PI * 2;
                box3.rotation.y += 1 * secs;
                box3.rotation.y %= Math.PI * 2;
                renderer.render(scene, camera);
            }
        };
        loop();

具体使用旋转的方法

  let lt:any = new Date();
        const state = {
            x: 0,
            y: 0,
            z: 0
        };
        const loop = function () {
            const now:any = new Date(),
                secs:any = (now - lt) / 1000;
            requestAnimationFrame(loop);
            if (secs >= 0.075) {
                lt = now;
                state.x += 0.5 * secs;
                state.y += 1.0 * secs;
                state.z += 1.5 * secs;
                state.x %= Math.PI * 2;
                // 设置角度
                box2.rotation.set(state.x, state.y, state.z);
                renderer.render(scene, camera);
            }
        };
        loop();

标签:scene,const,入门,THREE,three,camera,renderer,new,js
From: https://www.cnblogs.com/fangdongdemao/p/17369237.html

相关文章

  • 【2023 · CANN训练营第一季】昇腾AI入门Pytorch
    昇腾AI全栈架构华为AI全栈全场景解决方案为4层,分别为芯片层、芯片使能层、AI框架层和应用使能层。芯片基于统一、可扩展架构的系列化AIIP和芯片,为上层加速提供硬件基础。芯片产品:昇腾310和昇腾910的独立芯片,Nano-Tiny-Lite的非独立芯片。Ascend层,一切集成电路的核心,主要作用......
  • 第139篇:JS数组常用方法(map(),reduce(),foreach())
    好家伙,本篇为MDN文档数组方法的学习笔记Array.prototype.reduce()-JavaScript|MDN(mozilla.org)数组方法这块的知识缺了,补一下 1.map()方法map() 方法创建一个新数组,这个新数组由原数组中的每个元素都调用一次提供的函数后的返回值组成。constarray1=[1,4,9,......
  • XXL-JOB 入门学习
    参考教程主要参考了xxl-job快速入门指南,写的很详细,可以一步步按教程的走。项目环境搭建下载项目先到xxl-jobGitHub地址下载RELEASE的ZIP包。解压后,到MySQL执行doc目录下的db文件。视图页面打开xxl-job-admin模块。然后修改application.properties配置的......
  • 数据交换格式:XML、JSON
    XMLXML是什么可扩展标记语言(XML)是存储和交换数据的重要方法。它文档的形式类似于HTML,不过比HTML低级,都是标签里放内容。XML只包含少量的预定义标签,其他都由程序员来定义,只要数据的读者和编写者都知道标签的含义,标签就可以包含任何设计者希望的有用信息。XML的标签有单双,双标签包......
  • python 合并json
    importjson#foriinrange(800):f1=open('.\\'+str(0)+'.txt',"r")data1=f1.read()dic_str2=json.loads(str(data1).replace("'","\""))foriinrange(1,50):f=open('.\\'+......
  • Volatility 3 使用入门笔记
    下载恶意软件分析诀窍和工具DVD和vol3下载地址:https://codeload.github.com/ganboing/malwarecookbook/zip/refs/heads/master然后,下载vol3,并安装:https://codeload.github.com/volatilityfoundation/volatility3/zip/refs/heads/stable最初运行的时候,pythonD:\Application\v......
  • CMake 入门实战
    CMake入门实战本仓库是CMake入门实战的源代码。为了方便githubpages无法正常阅读的朋友,下面也附带上正文。但为了您更好的阅读体验,不妨前往原博客阅读:https://hahack.com/codes/cmake。什么是CMakeAllproblemsincomputersciencecanbesolvedbyanotherle......
  • 简单聊聊,使用Vue.js编写命令行界面,前端开发CLI的利器
    Temir介绍Temir,一个用Vue组件来编写命令行界面应用的工具.开发者只需要使用Vue就可以编写命令行应用,不需要任何额外的学习成本.<scriptlang="ts"setup>import{ref}from'@vue/runtime-core'import{TBox,TText}from'@temir/core'constcounter=ref(0)setIn......
  • JS闭包理解
    概念在一个函数中嵌套另一个函数,嵌套(内部)函数对其容器(外部)函数是私有的。闭包是一个可以自己拥有独立的环境与变量的表达式(通常是函数,因为ES6有块级作用域的概念)闭包是指有权访问另一个函数作用域中变量的函数。闭包作用:可以在函数外部访问到函数内部的局部变量;让这些变量始......
  • 01_JS技巧
    1.判断对象数据类型示例代码如下constisType=(type)=>(target)=>`[object${type}]`===Object.prototype.toString.call(target)constisArray=isType('Array')constisObject=isType('Object')constisBoolean=isType('......