微软Hololens学院教程- Holograms 101: Introduction with Device【微软教程已经更新,本文是老版本】...

这是老版本的教程,为了不耽误大家的时间,请直接看原文,本文仅供参考哦!原文链接:https://developer.microsoft.com/EN-US/WINDOWS/HOLOGRAPHIC/holograms_101

这篇文章将通过一个完整的实例来了解设备的核心特性,包括凝视,手势,声音输入和空间声音与空间映射。
先决条件

1.一个 Windows 10 PC 并安装有相应的软件tools installed..
2. 开发者模式的HoloLensconfigured for development. .

项目文件

1.下载此项目所需文件files。

2.将其保存在桌面或者其他易于找到的位置, 保持文件名为 Origami.

章节 1.“Holo”world 

目标
     1设置Unity。
     2制作全息对象。
     3看到你做的全息对象。
教程
  • 打开 Unity.
  • 选择 Open.
  • 选择本地项目 Origami 文件夹
  • 选择 Origami 点击 .
  • 由于 Origami项目中不含有场景, 需要将默认的场景保存成项目场景: 打开File / Save Scene As.
  • 将新场景命名为 Origami 然后点击保存按钮.

设置主相机

  • Hierarchy 面板中, 选择Main Camera.
  • Inspector 设置 transform position 为 0,0,0.
  • 找到Clear Flags 属性, 打开下拉列表将 Skybox 改为Solid color.
  • 点击 Background 的颜色选择器.
  • 设置 R, G, B,  A 都为 0.

配置场景

  1. Hierarchy 面板中, 点击Create -》 Create Empty.
  2. 右击 新GameObject 为它重新命名为 OrigamiCollection.
  3. 在 Project 面板中选择Holograms 文件夹,并双击打开:
  4. 拖拽Stage 到 Hierarchy面板中 ,使其成为 OrigamiCollection的子对象.
  5. 同理拖拽Sphere1
  6. 同理拖拽 Sphere2
  7. 删除Hierarchy 面板中的Directional Light
  8. Holograms 文件夹中, 拖拽 Lights 到Hierarchy面板中.
  9. Hierarchy中, 选中 OrigamiCollection.
  10. Inspector面板中, 设置其transform position 为0, -0.5, 2.0.
  11. 点击Play 按钮 来预览你的全息对象.
  12. 你会在你的预览窗口看到你的Origami 对象.
  13. 再次点击 Play 按钮停止预览模式.

将项目从 Unity 导出到Visual Studio

  • 在Unity中选择File > Build Settings.
  •  在Platform 列表下选择 Windows Store 然后点击Switch Platform.
  • 设置 SDK 为 Universal 10 ,设置 Build Type 为D3D.
  • 勾选 Unity C# Projects.
  • 点击 Add Open Scenes 来添加场景.
  • 点击 Build.
  • 创建一个新的文件夹命名为 "App".
  • 单击 App 文件夹.
  •  选中此文件夹.
  • Unity发布完成后, 一个新的 File Explorer 窗口将出现.
  • 打开 App 文件夹.
  • 双击打开Origami.sln.
  • 在 Visual Studio上部工具栏中, 将 Debug 设置为 Release ,将 ARM 变为 X86.
  • 点击 Device button旁边的箭头, 然后选择 Remote Device.
    • 设置 Address 为你的hololens的 IP 地址 . 如果你不知道你的设备的IP 地址, 开启hololens,选择 Settings > Network & Internet > Advanced Options 查看或者询问 Cortana "Hey Cortana, What's my IP address?"
    • 将 Authentication Mode 设置为 Universal.
    • 点击 Select
  • 点击 Debug > Start Without debugging 或者点击 Ctrl + F5. 如果这是你第一次发布应用到hololens, 你需要配对,具体需要输入设备的PIN码,在设置-》update-》for developers-》paired devices中查看。 pair it with Visual Studio.
  •  然后Origami项目开始发布部署到你的设备上并运行 .
  • 请戴上你的hololens来欣赏你发布的全息应用吧.

章节 2.Gaze 凝视
这一章将介绍hololens交互的三大方式的第一种,凝视

目标

  • 使用一个光标来可视化你的凝视点.

说明

  • 回到 Unity 项目, 如果 Build Settings 窗口还开着请把它关掉 .
  • Project 面板中选择Holograms文件夹.
  • 拖拽 Cursor 对象 到 Hierarchy 面板 的根节点下.
  •  双击Cursor 对象近距离查看、.
  • 在 Project 面板下右击Scripts 文件夹.
  •  点击Create sub-menu.
  •  选择C# Script.
  •  给脚本命名 WorldCursor
  •  选择 Hierarchy  面板中的Cursor 对象.
  • 拖拽 WorldCursor 脚本到 Inspector 面板中.
  • 双击WorldCursor 脚本用 Visual Studio打开.
  •  复制粘贴以下代码到WorldCursor.cs 然后保存.
WorldCursor.cs
using UnityEngine;public class WorldCursor : MonoBehaviour
{private MeshRenderer meshRenderer;// Use this for initializationvoid Start(){// Grab the mesh renderer that's on the same object as this script.meshRenderer = this.gameObject.GetComponentInChildren<MeshRenderer>();}// Update is called once per framevoid Update(){// Do a raycast into the world based on the user's// head position and orientation.var headPosition = Camera.main.transform.position;var gazeDirection = Camera.main.transform.forward;RaycastHit hitInfo;if (Physics.Raycast(headPosition, gazeDirection, out hitInfo)){// If the raycast hit a hologram...// Display the cursor mesh.meshRenderer.enabled = true;// Move the cursor to the point where the raycast hit.this.transform.position = hitInfo.point;// Rotate the cursor to hug the surface of the hologram.this.transform.rotation = Quaternion.FromToRotation(Vector3.up, hitInfo.normal);}else{// If the raycast did not hit a hologram, hide the cursor mesh.meshRenderer.enabled = false;}}
}
WorldCursor
  •  从新发布APP,通过File > Build Settings.从文件>构建设置重建应用程序。
  •   返回到以前用于部署到HoloLens的Visual Studio解决方案
  • 出现提示时,选择“重新加载所有”。
  • 单击调试 - >开始无调试或按Ctrl + F5。
  • 现在看看场景,注意光标如何与对象的形状进行交互。

章节 3.手势

 这一章,将添加手势支持,当用户选择场景中的纸球时,通过Unity设置有物理重力的纸球会掉落。

目标

  • 通过手势控制场景中的全息对象.

说明

  •  在Scripts 文件夹, 创建一个新的脚本并命名为 GazeGestureManager.
  •  拖拽GazeGestureManager 脚本到Hierarchy面板中的 OrigamiCollection 对象上  .
  • 用VS打开GazeGestureManager 脚本,将以下代码粘贴其中:
GazeGestureManager.cs
using UnityEngine;
using UnityEngine.VR.WSA.Input;public class GazeGestureManager : MonoBehaviour
{public static GazeGestureManager Instance { get; private set; }// Represents the hologram that is currently being gazed at.public GameObject FocusedObject { get; private set; }GestureRecognizer recognizer;// Use this for initializationvoid Awake(){Instance = this;// Set up a GestureRecognizer to detect Select gestures.recognizer = new GestureRecognizer();recognizer.TappedEvent += (source, tapCount, ray) =>{// Send an OnSelect message to the focused object and its ancestors.if (FocusedObject != null){FocusedObject.SendMessageUpwards("OnSelect");}};recognizer.StartCapturingGestures();}// Update is called once per framevoid Update(){// Figure out which hologram is focused this frame.GameObject oldFocusObject = FocusedObject;// Do a raycast into the world based on the user's// head position and orientation.var headPosition = Camera.main.transform.position;var gazeDirection = Camera.main.transform.forward;RaycastHit hitInfo;if (Physics.Raycast(headPosition, gazeDirection, out hitInfo)){// If the raycast hit a hologram, use that as the focused object.FocusedObject = hitInfo.collider.gameObject;}else{// If the raycast did not hit a hologram, clear the focused object.FocusedObject = null;}// If the focused object changed this frame,// start detecting fresh gestures again.if (FocusedObject != oldFocusObject){recognizer.CancelGestures();recognizer.StartCapturingGestures();}}
}
GazeGestureManager
  •  在Scripts 文件夹下创建一个新的脚本命名为 SphereCommands.
  •  展开Hierarchy面板中的OrigamiCollection 对象.
  •  拖拽SphereCommands 脚本到 Sphere1 对象上.
  •  拖拽SphereCommands 脚本到 Sphere2 对象上.
  • 用VS打开这个脚本并编辑,将以下代码复制粘贴到其中:
SphereCommands.cs
using UnityEngine;public class SphereCommands : MonoBehaviour
{// Called by GazeGestureManager when the user performs a Select gesturevoid OnSelect(){// If the sphere has no Rigidbody component, add one to enable physics.if (!this.GetComponent<Rigidbody>()){var rigidbody = this.gameObject.AddComponent<Rigidbody>();rigidbody.collisionDetectionMode = CollisionDetectionMode.Continuous;}}
}
SphereCommands
  • 再一次导出,发布部署 app 到你的 HoloLens.
  • 看着一个球.
  • 使用手势点击观看其下落效果.

章节 4.语音

这一章将添加两个语音指令,“Reset world”来返回初始场景状态,“Drop sphere”使得球体下落。

目标

  • 添加语音指令.
  • 创建一个对语音指令做出反应的全息对象.

说明

  •  在Scripts 文件夹下, 创建一个新的脚本并命名为 SpeechManager.
  •  拖拽SpeechManager 脚本到 OrigamiCollection 对象上
  •  用VS打开SpeechManager 脚本.
  • 复制粘贴以下代码到 SpeechManager.cs 中然后保存:
SpeechManager.cs
using System.Collections.Generic;
using System.Linq;
using UnityEngine;
using UnityEngine.Windows.Speech;public class SpeechManager : MonoBehaviour
{KeywordRecognizer keywordRecognizer = null;Dictionary<string, System.Action> keywords = new Dictionary<string, System.Action>();// Use this for initializationvoid Start(){keywords.Add("Reset world", () =>{// Call the OnReset method on every descendant object.this.BroadcastMessage("OnReset");});keywords.Add("Drop Sphere", () =>{var focusObject = GazeGestureManager.Instance.FocusedObject;if (focusObject != null){// Call the OnDrop method on just the focused object.focusObject.SendMessage("OnDrop");}});// Tell the KeywordRecognizer about our keywords.keywordRecognizer = new KeywordRecognizer(keywords.Keys.ToArray());// Register a callback for the KeywordRecognizer and start recognizing!keywordRecognizer.OnPhraseRecognized += KeywordRecognizer_OnPhraseRecognized;keywordRecognizer.Start();}private void KeywordRecognizer_OnPhraseRecognized(PhraseRecognizedEventArgs args){System.Action keywordAction;if (keywords.TryGetValue(args.text, out keywordAction)){keywordAction.Invoke();}}
}
SpeechManager
  •  用VS打开SphereCommands 脚本.
  • 更新为如下代码:
SphereCommands.cs
using UnityEngine;public class SphereCommands : MonoBehaviour
{Vector3 originalPosition;// Use this for initializationvoid Start(){// Grab the original local position of the sphere when the app starts.originalPosition = this.transform.localPosition;}// Called by GazeGestureManager when the user performs a Select gesturevoid OnSelect(){// If the sphere has no Rigidbody component, add one to enable physics.if (!this.GetComponent<Rigidbody>()){var rigidbody = this.gameObject.AddComponent<Rigidbody>();rigidbody.collisionDetectionMode = CollisionDetectionMode.Continuous;}}// Called by SpeechManager when the user says the "Reset world" commandvoid OnReset(){// If the sphere has a Rigidbody component, remove it to disable physics.var rigidbody = this.GetComponent<Rigidbody>();if (rigidbody != null){DestroyImmediate(rigidbody);}// Put the sphere back into its original local position.this.transform.localPosition = originalPosition;}// Called by SpeechManager when the user says the "Drop sphere" commandvoid OnDrop(){// Just do the same logic as a Select gesture.
        OnSelect();}
}
SphereCommands
  • 从新导出发布部署APP到 HoloLens.
  •  看着其中一个球,说"Drop Sphere".
  •  说"Reset World" 使他们回到初始的位置.

章节 5.空间声音

这一章,我们会为APP添加音乐,在特定操作上触发声音效果,我们将使用spatial sound特性给声音一个3D空间位置。

目标

  • 在你的世界中听见全息对象.

说明

  •  在Unity 选择 Edit > Project Settings > Audio
  • 在右侧的 Inspector 面板中, 找到 Spatializer Plugin 设置然后选择 MS HRTF Spatializer.
  • 在 Project 面板下从Holograms文件夹, 拖拽 Ambience 对象到 到 Hierarchy 面板下的OrigamiCollection 对象上.
  •  选择OrigamiCollection  对象,在右侧的Inspector面板 中找到Audio Source 组件. 改变以下属性值:
    • 选择 Spatialize property.
    •  选择Play On Awake.
    •  将Spatial Blend 改成 3D
    •  选择Loop property.
    • 展开 3D Sound Settings,  在Doppler Level 输入0.1.
    •  设置Volume RolloffCustom Rolloff.
  •  在Scripts 文件夹下, 创建一个新的脚本并命名为 SphereSounds.
  •  拖拽SphereSounds 脚本到 Sphere1Sphere2 对象上.
  •  用VS打开SphereSounds 脚本, 更新为以下代码并保存.
SphereSounds.cs
using UnityEngine;public class SphereSounds : MonoBehaviour
{AudioSource audioSource = null;AudioClip impactClip = null;AudioClip rollingClip = null;bool rolling = false;void Start(){// Add an AudioSource component and set up some defaultsaudioSource = gameObject.AddComponent<AudioSource>();audioSource.playOnAwake = false;audioSource.spatialize = true;audioSource.spatialBlend = 1.0f;audioSource.dopplerLevel = 0.0f;audioSource.rolloffMode = AudioRolloffMode.Custom;// Load the Sphere sounds from the Resources folderimpactClip = Resources.Load<AudioClip>("Impact");rollingClip = Resources.Load<AudioClip>("Rolling");}// Occurs when this object starts colliding with another objectvoid OnCollisionEnter(Collision collision){// Play an impact sound if the sphere impacts strongly enough.if (collision.relativeVelocity.magnitude >= 0.1f){audioSource.clip = impactClip;audioSource.Play();}}// Occurs each frame that this object continues to collide with another objectvoid OnCollisionStay(Collision collision){Rigidbody rigid = this.gameObject.GetComponent<Rigidbody>();// Play a rolling sound if the sphere is rolling fast enough.if (!rolling && rigid.velocity.magnitude >= 0.01f){rolling = true;audioSource.clip = rollingClip;audioSource.Play();}// Stop the rolling sound if rolling slows down.else if (rolling && rigid.velocity.magnitude < 0.01f){rolling = false;audioSource.Stop();}}// Occurs when this object stops colliding with another objectvoid OnCollisionExit(Collision collision){// Stop the rolling sound if the object falls off and stops colliding.if (rolling){rolling = false;audioSource.Stop();}}
}
SphereSounds
  • 保存脚本,返回到Unity中.
  • 导出发布并部署 app 到你的 HoloLens.
  • 移动远近来感受声音的变化.

章节 6.空间映射

现在我们将使用空间映射特性将游戏板放置在现实世界中的真实对象上。

目标

  • 把你的现实世界变成一个虚拟世界.
  • 把你的全息图放在你想把它放置的位置.

步骤

  •  在Unity 中, 点击Project 面板下的 Holograms 文件夹.
  • Spatial Mapping asset 拖拽到 Hierarchy面板的根节点.
  •  点击Hierarchy 面板下的Spatial Mapping 对象  .
  • 在右侧的 Inspector 面板, 改变如下设置:
    • 选择 Draw Visual Meshes box.
    •  定位到Draw Material 然后点击它右侧的圆. 在顶部的搜索字段中键入“wireframe”。单击结果,然后关闭窗口。执行此操作时,Draw Material的值应设置为线框.
  • 导出,发布并将应用程序部署到您的HoloLens。   
  • 当应用程序运行时,线框网格将覆盖你的现实世界。
  • 观看滚动球体将如何从平台掉落到地板上!

现在,我们将向您展示如何将OrigamiCollection移动到新位置:

  •  在Scripts 文件夹下, 创建一个新的脚本并命名为 TapToPlaceParent.
  •  在Hierarchy 面板下,展开 OrigamiCollection 然后选择 Stage 对象.
  •  拖拽TapToPlaceParent 脚本到 Stage 对象上.
  •  用VS打开TapToPlaceParent 脚本, 更新为如下代码:
TapToPlaceParent.cs
using UnityEngine;public class TapToPlaceParent : MonoBehaviour
{bool placing = false;// Called by GazeGestureManager when the user performs a Select gesturevoid OnSelect(){// On each Select gesture, toggle whether the user is in placing mode.placing = !placing;// If the user is in placing mode, display the spatial mapping mesh.if (placing){SpatialMapping.Instance.DrawVisualMeshes = true;}// If the user is not in placing mode, hide the spatial mapping mesh.else{SpatialMapping.Instance.DrawVisualMeshes = false;}}// Update is called once per framevoid Update(){// If the user is in placing mode,// update the placement to match the user's gaze.if (placing){// Do a raycast into the world that will only hit the Spatial Mapping mesh.var headPosition = Camera.main.transform.position;var gazeDirection = Camera.main.transform.forward;RaycastHit hitInfo;if (Physics.Raycast(headPosition, gazeDirection, out hitInfo,30.0f, SpatialMapping.PhysicsRaycastMask)){// Move this object's parent object to// where the raycast hit the Spatial Mapping mesh.this.transform.parent.position = hitInfo.point;// Rotate this object's parent object to face the user.Quaternion toQuat = Camera.main.transform.localRotation;toQuat.x = 0;toQuat.z = 0;this.transform.parent.rotation = toQuat;}}}
}
TapToPlaceParent
  • 导出,构建和部署应用程序.
  • 现在,您现在应该能够通过注视它,使用选择手势,然后移动到一个新的位置,并再次使用选择手势,将对象放在特定的位置。

章节 7.全息的乐趣

目标

  • 显示全息对象背后的世界入口的效果.

步骤

  • 在 Project 面板下打开Holograms 文件夹:
    •  拖拽Underworld 到 Hierarchy 面板下成为 OrigamiCollection 的孩子.
  • Scripts 文件夹下, 创建一个新的脚本并命名为 HitTarget.
  •  在Hierarchy 面板下, 展开 OrigamiCollection.
  •  展开Stage 对象然后选择 Target 对象 (blue fan).
  • 拖拽HitTarget 脚本到 Target 对象上.
  •  用VS打开HitTarget 脚本, 更新为以下代码:
HitTarget.cs
using UnityEngine;public class HitTarget : MonoBehaviour
{// These public fields become settable properties in the Unity editor.public GameObject underworld;public GameObject objectToHide;// Occurs when this object starts colliding with another objectvoid OnCollisionEnter(Collision collision){// Hide the stage and show the underworld.objectToHide.SetActive(false);underworld.SetActive(true);// Disable Spatial Mapping to let the spheres enter the underworld.SpatialMapping.Instance.MappingEnabled = false;}
}
HitTarget
  • 在Unity, 选择 Target 对象.
  • Hit Target 组件中可见两个公共属性, 需要引用场景中的对象:
    • 拖拽Hierarchy 面板下的 Underworld 对象到 Hit Target 组件下的 Underworld 属性中.
    • 拖拽Hierarchy 面板下的 Stage对象到 Hit Target 组件下的 Object to Hide 属性中。
  • 导出发布部署 app.
  •  将折纸集合放在地板上,然后使用选择手势使球体下降。
  • 当球碰到目标(blue fan)时,将发生爆炸。收集将被隐藏,一个洞会出现。

原文链接:https://developer.microsoft.com/en-us/windows/holographic/holograms_101

如有翻译上的错误请指正,谢谢

转载于:https://www.cnblogs.com/qichun/p/6031499.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/457642.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python seaborn boxplot_python - 如何将文本框添加到Seaborn Boxplot? - 堆栈内存溢出

我试图在框图中插入一个文本框&#xff0c;但是出了点问题。 让我们先绘制箱线图&#xff1a;import pandas as pdimport matplotlib.pyplot as pltimport seaborn as sbdf_data pd.read_hdf(data.h5, keyfdf_data)##print(df_data)fig, (ax1, ax2) plt.subplots(1,2,gridspe…

JS_11正则表达式和字符串方法

正则表达式和字符串方法 正则表达式 创建正则对象 构造函数字面量 匹配模式 i&#xff1a;忽略大小写m&#xff1a;多行匹配g&#xff1a;全局匹配 正则语法 正则作用/a/检查是否有a/a|b/检查是否有a或b{}量词&#xff0c;如{1,3}匹配1到3次&#xff0c;{m,}匹配m次以上…

qtableview点击行将整行数据传过去_可以实时获取数据的Database Asset插件

前言&#xff1a;Goby之前开放的插件入口点较少&#xff0c;大家只能在扫描前、扫描后执行事件&#xff0c;无法参与扫描过程中来。为实现更多场景的应用及提高扫描效率&#xff08;如&#xff1a;后台爆破子域名等&#xff09;&#xff0c;Goby开放了一些新的API&#xff1a;事…

git 笔记

版本库1.repository在一个合适的地方&#xff0c;创建一个空目录$ mkdir learngit$ cd learngit$ pwd/User/leon/learngitpwd命令用于显示当前的目录&#xff0c;在我的电脑上&#xff0c;这个仓库位于/user/michael/learngit2.git init 将当前目录变成git 可以管理的仓库。$ g…

github 开源 代码 学习 集合(转载)

一个支持多种item类型的recycleView依赖注入库 1.通过注解的方式方便的把ViewHolder注入到recycleView中。 2.去除findViewByID等冗余操作。 3.去除编写adapter那些冗余逻辑&#xff0c;只需要编写proxy和holder即可快速的实现淘宝首页那样复杂的页面。https://github.com/s94…

JS_12 DOM

DOM 操作 HTML DOM Document Object Model&#xff0c;文档对象模型&#xff0c;用js操作文档对象 [外链图片转存失败(img-Dygj4uK9-1562680086020)(image/domtree.gif)] 节点&#xff1a;构成网页最基本的部分&#xff0c;网页的每一部分都是一个节点 文档节点&#xff1a;…

星星排序python_python中怎么实现星星排列

python中怎么实现星星排列&#xff1f;下面给大家带来几种排列阵型。星星阵型1def stars1(n):for i in range(1,n1):str "*"*iprint strif __name__ "__main__":stars1(5)星星阵型2def stars2(n):for i in range(1,n1):str **(n1-i)print strif __name_…

Kendo UI开发教程:Kendo UI模板概述

2019独角兽企业重金招聘Python工程师标准>>> Kendo UI框架提供了一个易用&#xff0c;高性能的JavaScript模板引擎。通过模板可以创建一个HTML片段然后可以和JavaScript数据合并成最终的HTML元素。Kendo 模板侧重于UI显示&#xff0c;支持关键的模板功能&#xff0c…

JS_13原型与原型链

原型与原型链 原型 每一个函数都有一个属性&#xff1a;prototype,默认指向object空对象&#xff0c;就是原型对象,原型对象有一个constructor属性&#xff0c;指向函数对象每一个实例化对象都有一个属性 proto ,默认指向构造函数的原型对象&#xff08;是构造函数原型对象的…

ajax数据保存及解析

1. $(#frmCam).serialize()&#xff1b;serialize() 方法通过序列化表单值&#xff0c;创建 URL 编码文本字符串。 2.自动对应ID和值 window.camConfig [<%(camConfig) %>]; if (camConfig.length>0) { for(var property in cam…

python和revit_pyRevit系列教程1

有没有人和我一样&#xff0c;想要自己写一些小功能来用(zhuang)用(bi)&#xff0c;但苦于C#太难学了&#xff0c;不得不作罢。话说感受过Python的美好&#xff0c;怎么能忍受C#的大括号&#xff01;毕竟人生苦短&#xff0c;我用Python&#xff01;好吧&#xff0c;我承认是我…

【leetcode】104. Maximum Depth of Binary Tree

1. 题目 Given a binary tree, find its maximum depth. The maximum depth is the number of nodes along the longest path from the root node down to the farthest leaf node. 2. 思路 递归到左、右子树的max值&#xff0c;1. 3. 代码 /*** Definition for a binary tree …

JS_14 执行上下文与执行上下文栈

执行上下文和执行上下文栈 变量提升和函数提升 变量提升 所用使用var定义的变量&#xff0c;在程序运行前会被先定义&#xff0c;并赋初值为underfind&#xff0c;保存到其执行上下文中 函数提升 在调用函数&#xff0c;执行函数体之前&#xff0c;会先执行函数定义&#xff…

shell编程-变量

1.Bash用户自定义变量 【局部变量】 【按数据存储分类】&#xff1a;整型、浮点型、字符串型、日期型 【变量定义】&#xff1a;x5,y6,z$x$y56,m$(($x$y))11 【Bash变量默认都为字符串型&#xff0c;等号左右不可以有空格】 【变量叠加】&#xff1a;x"$x"123,x${x}3…

JS_15作用域与作用域链

作用域与作用域链 作用域 类别 全局作用域函数作用域块作用域&#xff1a;Es6时出现&#xff0c;之前没有 作用域与执行上下文 区别 创建时机不同 全局作用域外&#xff0c;每个函数都有自己的作用域&#xff0c;作用域在函数创建时就创建了&#xff0c;而不是在调用时全局执…

多线程调用同一个对象的方法_多线程之如何创建和使用线程

一、创建线程和使用线程方式1.1 继承Thread让线程类继承自Thread类&#xff0c;然后重写run()&#xff0c;把需要多线程调用的代码放到run()中。但是需要开启线程的时候不能调用run方法&#xff0c;而是需要调用start()方法。/*** 本类用于演示第一种实现多线程的方式*/ class…

struts2的namespace的问题

<?xml version"1.0" encoding"UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/dtds/struts-2.1.dtd"> <struts> <inc…

JS_16闭包

闭包 什么是闭包 理解1&#xff1a;闭包是嵌套的内部函数理解2&#xff1a;闭包是包含被引用变量&#xff08;函数&#xff09;的对象 闭包产生的条件 函数嵌套子函数调用了父函数的数据父函数被调用了&#xff08;子函数不一定需要被调用&#xff0c;只需要执行函数定义即可&…

[Intel Edison开发板] 02、Edison开发板入门

一、前言 Start from the link: 开始学习的链接 上面链接是官网的教程&#xff0c;按照教程可以开发板入门&#xff1a; 其中第一步是了解开发板&#xff0c;涉及到如何组装、如何连线、一些主要的接口简单介绍等信息&#xff1b;第二步主要是介绍如何用官方提供的工具进行配置…

python apscheduler一次只有一个job_Python使用APScheduler实现定时任务过程解析

前言APScheduler是基于Quartz的一个Python定时任务框架。提供了基于日期、固定时间间隔以及crontab类型的任务&#xff0c;并且可以持久化任务。一、安装APSchedulerpip install apscheduler二、基本概念APScheduler有四大组件&#xff1a;1、触发器 triggers &#xff1a;触发…