2023-03-06 3D飞机模型 全屏功能

首先要安装Three.js

 import * as Three from 'three'

 import { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader'

   import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls'

    import { DRACOLoader } from 'three/examples/jsm/loaders/DRACOLoader'

    import screenfull from 'screenfull'   全屏需要安装的,如果不做全屏功能就不需要引入

其次模型的位置放入public,再到node_models里面找到Three里面的js,把draco文件复制到publici里面,引入模型.glb格式,格式要注意 loader.load('/波音.gltf.glb', (gltf) => {})

<templatThreee>

    <section>

        <section id="container"></section>

        <el-button style="color:#918F8F" @click="click">

            {{isFullscreen?'退出全屏':'全屏'}}

        </el-button>

        <div id="canvas"></div>

    </section>

</template>


<script>

    import * as Three from 'three'

    import { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader'

    import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls'

    import { DRACOLoader } from 'three/examples/jsm/loaders/DRACOLoader'

    // import $ from 'jquery'

    import screenfull from 'screenfull'

    export default {

        name: 'Index',

        data() {

            return {

                camera: null,

                scene: null,

                renderer: null,

                mesh: null,

                isFullscreen: false,

                font: {}

            }

        },

        mounted() {

            this.init()

            this.animate()

        },

        beforeDestroy() {

            this.destroy()

        },

        methods: {

            init() {

                if (screenfull.isEnabled) {

                    screenfull.on('change', this.change)

                }

                const container = document.getElementById('container')

                this.camera = new Three.PerspectiveCamera(90, container.clientWidth / container.clientHeight, 0.1, 10000)

                this.renderer = new Three.WebGLRenderer(

                    {

                        antialias: true, // true/false表示是否开启反锯齿

                        alpha: true, // true/false 表示是否可以设置背景色透明

                        precision: 'highp', // highp/mediump/lowp 表示着色精度选择

                        premultipliedAlpha: false, // true/false 表示是否可以设置像素深度(用来度量图像的分率)

                        preserveDrawingBuffer: true, // true/false 表示是否保存绘图缓冲

                        maxLights: 3, // 最大灯光数

                        stencil: true // false/true 表示是否使用模板字体或图案

                    })

                // this.camera.position.set(200, 200, 400)

                this.camera.position.set(40, 40, 40);

                this.scene = new Three.Scene()

                this.renderer.setClearColor(new Three.Color(0xF7F2F1))

                this.renderer.setSize(container.clientWidth, container.clientHeight)

                this.renderer.shadowMap.enabled = true

                container.appendChild(this.renderer.domElement)

                this.controls = new OrbitControls(this.camera, this.renderer.domElement)

                this.controls.target = new Three.Vector3(0, 0, 0)

                let axisHelper = new Three.AxesHelper(20);

                this.scene.add(axisHelper);

                // 创建光源

                const spotLight = new Three.SpotLight(0xffffff, 5); //(光照颜色,光照强度)

                console.log(spotLight, 'list');

                // 设置光源位置

                spotLight.position.set(0, 20, 20);

                // 将光源添加到场景中

                this.scene.add(spotLight);

                let canvas = document.createElement("canvas");

                canvas.width = 200;

                canvas.height = 100;

                let ctx = canvas.getContext("2d");

                ctx.fillStyle = "#000";

                ctx.font = "20px 宋体";

                ctx.lineWidth = 10;

                ctx.fillText("模型", 154, 16);

                let texture = new Three.Texture(canvas);

                texture.needsUpdate = true;

                let material = new Three.SpriteMaterial({ map: texture });

                let text = new Three.Sprite(material);

                text.scale.set(0.5 * 100, 0.25 * 100, 0.75 * 100);

                text.position.set(0, 0, 50);

                this.scene.add(text)

                this.loadLight()

                this.load3D()

                this.atrs()

            },

            click() {

                if (!screenfull.isEnabled) {

                    this.$message({ message: '你的浏览器不支持全屏', type: 'warning' })

                    return false

                }

                screenfull.toggle()

            },

        //点击全屏按钮全屏 

            change() {

                this.isFullscreen = screenfull.isFullscreen

            },

           showTip() {

                if (this.lastPick) {

                    const properties = this.lastPick.object.parent.properties

                    console.log(properties, 'properties');

                    this.tooltip.textContent = properties.name

                    this.tooltip.style.visibility = 'visible'

                } else {

                    this.tooltip.style.visibility = 'hidden'

                }

            },

            destroy() {

                if (screenfull.isEnabled) {

                    screenfull.off('change', this.change)

                }

            },

            load3D() {

                const loader = new GLTFLoader()

                const dracoLoader = new DRACOLoader()

                dracoLoader.setDecoderPath('/draco/')

                dracoLoader.preload()

                loader.setDRACOLoader(dracoLoader)

                loader.load('/波音.gltf.glb', (gltf) => {

                    this.scene.add(gltf.scene)

                    this.renderer.render(this.scene, this.camera)

                }, (xhr) => {

                    console.log((xhr.loaded / xhr.total) * 100 + '% loaded')

                }, (error) => {

                    console.error(error)

                })

            },

            loadLight() {

                // 点光源

                // const point = new Three.PointLight(0xffffff)

                // point.position.set(4000, 4000, 4000) // 点光源位置

                // this.scene.add(point) // 点光源添加到场景中

                // 环境光

                const ambient = new Three.AmbientLight(0xFFFFFF)

                this.scene.add(ambient)

            },

            animate() {

                requestAnimationFrame(this.animate)

                this.renderer.render(this.scene, this.camera)

            },

        }

    }

</script>

<style scoped>

    #container {

        width: 100%;

        height: calc(100vh - 84px);

    }

</style>

效果图如下:

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,569评论 4 363
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,499评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,271评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,087评论 0 209
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,474评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,670评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,911评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,636评论 0 202
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,397评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,607评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,093评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,418评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,074评论 3 237
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,092评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,865评论 0 196
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,726评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,627评论 2 270

推荐阅读更多精彩内容