Unity 之 c# 版的 CharacterMotor
- using System;
- using System.Collections;
- using UnityEngine;
- // This class just convert from CharacterMotor.js to C#
- [RequireComponent(typeof(CharacterController))]
- [AddComponentMenu("Character/Character Motor")]
- public class CharacterMotor : MonoBehaviour
- {
- bool canControl = true;
- bool useFixedUpdate = true;
- // For the next variables, @System.NonSerialized tells Unity to not serialize the variable or show it in the inspector view.
- // Very handy for organization!
- // The current global direction we want the character to move in.
- [NonSerialized]
- public Vector3 inputMoveDirection = Vector3.zero;
- // Is the jump button held down? We use this interface instead of checking
- // for the jump button directly so this script can also be used by AIs.
- [NonSerialized]
- public bool inputJump = false;
- class CharacterMotorMovement
- {
- // The maximum horizontal speed when moving
- public float maxForwardSpeed = 10.0f;
- public float maxSidewaysSpeed = 10.0f;
- public float maxBackwardsSpeed = 10.0f;
- // Curve for multiplying speed based on slope (negative = downwards)
- public AnimationCurve slopeSpeedMultiplier = new AnimationCurve(new Keyframe(-, ), new Keyframe(, ), new Keyframe(, ));
- // How fast does the character change speeds? Higher is faster.
- public float maxGroundAcceleration = 30.0f;
- public float maxAirAcceleration = 20.0f;
- // The gravity for the character
- public float gravity = 10.0f;
- public float maxFallSpeed = 20.0f;
- // For the next variables, @System.NonSerialized tells Unity to not serialize the variable or show it in the inspector view.
- // Very handy for organization!
- // The last collision flags returned from controller.Move
- [NonSerialized]
- public CollisionFlags collisionFlags;
- // We will keep track of the character's current velocity,
- [NonSerialized]
- public Vector3 velocity;
- // This keeps track of our current velocity while we're not grounded
- [NonSerialized]
- public Vector3 frameVelocity = Vector3.zero;
- [NonSerialized]
- public Vector3 hitPoint = Vector3.zero;
- [NonSerialized]
- public Vector3 lastHitPoint = new Vector3(Mathf.Infinity, , );
- }
- CharacterMotorMovement movement = new CharacterMotorMovement();
- enum MovementTransferOnJump
- {
- None, // The jump is not affected by velocity of floor at all.
- InitTransfer, // Jump gets its initial velocity from the floor, then gradualy comes to a stop.
- PermaTransfer, // Jump gets its initial velocity from the floor, and keeps that velocity until landing.
- PermaLocked // Jump is relative to the movement of the last touched floor and will move together with that floor.
- }
- // We will contain all the jumping related variables in one helper class for clarity.
- class CharacterMotorJumping
- {
- // Can the character jump?
- public bool enabled = true;
- // How high do we jump when pressing jump and letting go immediately
- public float baseHeight = 1.6f;
- // We add extraHeight units (meters) on top when holding the button down longer while jumping
- public float extraHeight = 1.6f;
- // How much does the character jump out perpendicular to the surface on walkable surfaces?
- // 0 means a fully vertical jump and 1 means fully perpendicular.
- public float perpAmount = 2.0f;
- // How much does the character jump out perpendicular to the surface on too steep surfaces?
- // 0 means a fully vertical jump and 1 means fully perpendicular.
- public float steepPerpAmount = 1.5f;
- // For the next variables, @System.NonSerialized tells Unity to not serialize the variable or show it in the inspector view.
- // Very handy for organization!
- // Are we jumping? (Initiated with jump button and not grounded yet)
- // To see if we are just in the air (initiated by jumping OR falling) see the grounded variable.
- [NonSerialized]
- public bool jumping = false;
- [NonSerialized]
- public bool holdingJumpButton = false;
- // the time we jumped at (Used to determine for how long to apply extra jump power after jumping.)
- [NonSerialized]
- public float lastStartTime = 0.0f;
- [NonSerialized]
- public float lastButtonDownTime = -100f;
- [NonSerialized]
- public Vector3 jumpDir = Vector3.up;
- }
- CharacterMotorJumping jumping = new CharacterMotorJumping();
- class CharacterMotorMovingPlatform
- {
- public bool enabled = true;
- public MovementTransferOnJump movementTransfer = MovementTransferOnJump.PermaTransfer;
- [NonSerialized]
- public Transform hitPlatform;
- [NonSerialized]
- public Transform activePlatform;
- [NonSerialized]
- public Vector3 activeLocalPoint;
- [NonSerialized]
- public Vector3 activeGlobalPoint;
- [NonSerialized]
- public Quaternion activeLocalRotation;
- [NonSerialized]
- public Quaternion activeGlobalRotation;
- [NonSerialized]
- public Matrix4x4 lastMatrix;
- [NonSerialized]
- public Vector3 platformVelocity;
- [NonSerialized]
- public bool newPlatform;
- }
- CharacterMotorMovingPlatform movingPlatform = new CharacterMotorMovingPlatform();
- class CharacterMotorSliding
- {
- // Does the character slide on too steep surfaces?
- public bool enabled = true;
- // How fast does the character slide on steep surfaces?
- public float slidingSpeed = 15f;
- // How much can the player control the sliding direction?
- // If the value is 0.5 the player can slide sideways with half the speed of the downwards sliding speed.
- public float sidewaysControl = 1.0f;
- // How much can the player influence the sliding speed?
- // If the value is 0.5 the player can speed the sliding up to 150% or slow it down to 50%.
- public float speedControl = 0.4f;
- }
- CharacterMotorSliding sliding = new CharacterMotorSliding();
- [NonSerialized]
- public bool grounded = true;
- [NonSerialized]
- public Vector3 groundNormal = Vector3.zero;
- Vector3 lastGroundNormal = Vector3.zero;
- Transform tr;
- CharacterController controller;
- void Awake()
- {
- controller = gameObject.GetComponent<CharacterController>();
- tr = transform;
- }
- private void UpdateFunction()
- {
- // We copy the actual velocity into a temporary variable that we can manipulate.
- var velocity = movement.velocity;
- // Update velocity based on input
- velocity = ApplyInputVelocityChange(velocity);
- // Apply gravity and jumping force
- velocity = ApplyGravityAndJumping(velocity);
- // Moving platform support
- var moveDistance = Vector3.zero;
- if (MoveWithPlatform())
- {
- var newGlobalPoint = movingPlatform.activePlatform.TransformPoint(movingPlatform.activeLocalPoint);
- moveDistance = (newGlobalPoint - movingPlatform.activeGlobalPoint);
- if (moveDistance != Vector3.zero)
- controller.Move(moveDistance);
- // Support moving platform rotation as well:
- var newGlobalRotation = movingPlatform.activePlatform.rotation * movingPlatform.activeLocalRotation;
- var rotationDiff = newGlobalRotation * Quaternion.Inverse(movingPlatform.activeGlobalRotation);
- var yRotation = rotationDiff.eulerAngles.y;
- if (yRotation != )
- {
- // Prevent rotation of the local up vector
- tr.Rotate(, yRotation, );
- }
- }
- // Save lastPosition for velocity calculation.
- var lastPosition = tr.position;
- // We always want the movement to be framerate independent. Multiplying by Time.deltaTime does this.
- var currentMovementOffset = velocity * Time.deltaTime;
- // Find out how much we need to push towards the ground to avoid loosing grouning
- // when walking down a step or over a sharp change in slope.
- var pushDownOffset = Mathf.Max(controller.stepOffset, new Vector3(currentMovementOffset.x, , currentMovementOffset.z).magnitude);
- if (grounded)
- currentMovementOffset -= pushDownOffset * Vector3.up;
- // Reset variables that will be set by collision function
- movingPlatform.hitPlatform = null;
- groundNormal = Vector3.zero;
- // Move our character!
- movement.collisionFlags = controller.Move(currentMovementOffset);
- movement.lastHitPoint = movement.hitPoint;
- lastGroundNormal = groundNormal;
- if (movingPlatform.enabled && movingPlatform.activePlatform != movingPlatform.hitPlatform)
- {
- if (movingPlatform.hitPlatform != null)
- {
- movingPlatform.activePlatform = movingPlatform.hitPlatform;
- movingPlatform.lastMatrix = movingPlatform.hitPlatform.localToWorldMatrix;
- movingPlatform.newPlatform = true;
- }
- }
- // Calculate the velocity based on the current and previous position.
- // This means our velocity will only be the amount the character actually moved as a result of collisions.
- var oldHVelocity = new Vector3(velocity.x, , velocity.z);
- movement.velocity = (tr.position - lastPosition) / Time.deltaTime;
- var newHVelocity = new Vector3(movement.velocity.x, , movement.velocity.z);
- // The CharacterController can be moved in unwanted directions when colliding with things.
- // We want to prevent this from influencing the recorded velocity.
- if (oldHVelocity == Vector3.zero)
- {
- movement.velocity = new Vector3(, movement.velocity.y, );
- }
- else
- {
- var projectedNewVelocity = Vector3.Dot(newHVelocity, oldHVelocity) / oldHVelocity.sqrMagnitude;
- movement.velocity = oldHVelocity * Mathf.Clamp01(projectedNewVelocity) + movement.velocity.y * Vector3.up;
- }
- if (movement.velocity.y < velocity.y - 0.001)
- {
- if (movement.velocity.y < )
- {
- // Something is forcing the CharacterController down faster than it should.
- // Ignore this
- movement.velocity.y = velocity.y;
- }
- else
- {
- // The upwards movement of the CharacterController has been blocked.
- // This is treated like a ceiling collision - stop further jumping here.
- jumping.holdingJumpButton = false;
- }
- }
- // We were grounded but just loosed grounding
- if (grounded && !IsGroundedTest())
- {
- grounded = false;
- // Apply inertia from platform
- if (movingPlatform.enabled &&
- (movingPlatform.movementTransfer == MovementTransferOnJump.InitTransfer ||
- movingPlatform.movementTransfer == MovementTransferOnJump.PermaTransfer)
- )
- {
- movement.frameVelocity = movingPlatform.platformVelocity;
- movement.velocity += movingPlatform.platformVelocity;
- }
- SendMessage("OnFall", SendMessageOptions.DontRequireReceiver);
- // We pushed the character down to ensure it would stay on the ground if there was any.
- // But there wasn't so now we cancel the downwards offset to make the fall smoother.
- tr.position += pushDownOffset * Vector3.up;
- }
- // We were not grounded but just landed on something
- else if (!grounded && IsGroundedTest())
- {
- grounded = true;
- jumping.jumping = false;
- SubtractNewPlatformVelocity();
- SendMessage("OnLand", SendMessageOptions.DontRequireReceiver);
- }
- // Moving platforms support
- if (MoveWithPlatform())
- {
- // Use the center of the lower half sphere of the capsule as reference point.
- // This works best when the character is standing on moving tilting platforms.
- movingPlatform.activeGlobalPoint = tr.position + Vector3.up * (controller.center.y - (controller.height * 0.5f) + controller.radius);
- movingPlatform.activeLocalPoint = movingPlatform.activePlatform.InverseTransformPoint(movingPlatform.activeGlobalPoint);
- // Support moving platform rotation as well:
- movingPlatform.activeGlobalRotation = tr.rotation;
- movingPlatform.activeLocalRotation = Quaternion.Inverse(movingPlatform.activePlatform.rotation) * movingPlatform.activeGlobalRotation;
- }
- }
- void FixedUpdate()
- {
- if (movingPlatform.enabled)
- {
- if (movingPlatform.activePlatform != null)
- {
- if (!movingPlatform.newPlatform)
- {
- movingPlatform.platformVelocity = (
- movingPlatform.activePlatform.localToWorldMatrix.MultiplyPoint3x4(movingPlatform.activeLocalPoint)
- - movingPlatform.lastMatrix.MultiplyPoint3x4(movingPlatform.activeLocalPoint)
- ) / Time.deltaTime;
- }
- movingPlatform.lastMatrix = movingPlatform.activePlatform.localToWorldMatrix;
- movingPlatform.newPlatform = false;
- }
- else
- {
- movingPlatform.platformVelocity = Vector3.zero;
- }
- }
- if (useFixedUpdate)
- UpdateFunction();
- }
- void Update()
- {
- if (!useFixedUpdate)
- UpdateFunction();
- }
- Vector3 ApplyInputVelocityChange(Vector3 velocity)
- {
- if (!canControl)
- inputMoveDirection = Vector3.zero;
- // Find desired velocity
- Vector3 desiredVelocity;
- if (grounded && TooSteep())
- {
- // The direction we're sliding in
- desiredVelocity = new Vector3(groundNormal.x, , groundNormal.z).normalized;
- // Find the input movement direction projected onto the sliding direction
- var projectedMoveDir = Vector3.Project(inputMoveDirection, desiredVelocity);
- // Add the sliding direction, the spped control, and the sideways control vectors
- desiredVelocity = desiredVelocity + projectedMoveDir * sliding.speedControl + (inputMoveDirection - projectedMoveDir) * sliding.sidewaysControl;
- // Multiply with the sliding speed
- desiredVelocity *= sliding.slidingSpeed;
- }
- else
- desiredVelocity = GetDesiredHorizontalVelocity();
- if (movingPlatform.enabled && movingPlatform.movementTransfer == MovementTransferOnJump.PermaTransfer)
- {
- desiredVelocity += movement.frameVelocity;
- desiredVelocity.y = ;
- }
- if (grounded)
- desiredVelocity = AdjustGroundVelocityToNormal(desiredVelocity, groundNormal);
- else
- velocity.y = ;
- // Enforce max velocity change
- var maxVelocityChange = GetMaxAcceleration(grounded) * Time.deltaTime;
- var velocityChangeVector = (desiredVelocity - velocity);
- if (velocityChangeVector.sqrMagnitude > maxVelocityChange * maxVelocityChange)
- {
- velocityChangeVector = velocityChangeVector.normalized * maxVelocityChange;
- }
- // If we're in the air and don't have control, don't apply any velocity change at all.
- // If we're on the ground and don't have control we do apply it - it will correspond to friction.
- if (grounded || canControl)
- velocity += velocityChangeVector;
- if (grounded)
- {
- // When going uphill, the CharacterController will automatically move up by the needed amount.
- // Not moving it upwards manually prevent risk of lifting off from the ground.
- // When going downhill, DO move down manually, as gravity is not enough on steep hills.
- velocity.y = Mathf.Min(velocity.y, );
- }
- return velocity;
- }
- Vector3 ApplyGravityAndJumping(Vector3 velocity)
- {
- if (!inputJump || !canControl)
- {
- jumping.holdingJumpButton = false;
- jumping.lastButtonDownTime = -;
- }
- if (inputJump && jumping.lastButtonDownTime < && canControl)
- jumping.lastButtonDownTime = Time.time;
- if (grounded)
- velocity.y = Mathf.Min(, velocity.y) - movement.gravity * Time.deltaTime;
- else
- {
- velocity.y = movement.velocity.y - movement.gravity * Time.deltaTime * ;
- // When jumping up we don't apply gravity for some time when the user is holding the jump button.
- // This gives more control over jump height by pressing the button longer.
- if (jumping.jumping && jumping.holdingJumpButton)
- {
- // Calculate the duration that the extra jump force should have effect.
- // If we're still less than that duration after the jumping time, apply the force.
- if (Time.time < jumping.lastStartTime + jumping.extraHeight / CalculateJumpVerticalSpeed(jumping.baseHeight))
- {
- // Negate the gravity we just applied, except we push in jumpDir rather than jump upwards.
- velocity += jumping.jumpDir * movement.gravity * Time.deltaTime;
- }
- }
- // Make sure we don't fall any faster than maxFallSpeed. This gives our character a terminal velocity.
- velocity.y = Mathf.Max(velocity.y, -movement.maxFallSpeed);
- }
- if (grounded)
- {
- // Jump only if the jump button was pressed down in the last 0.2 seconds.
- // We use this check instead of checking if it's pressed down right now
- // because players will often try to jump in the exact moment when hitting the ground after a jump
- // and if they hit the button a fraction of a second too soon and no new jump happens as a consequence,
- // it's confusing and it feels like the game is buggy.
- if (jumping.enabled && canControl && (Time.time - jumping.lastButtonDownTime < 0.2))
- {
- grounded = false;
- jumping.jumping = true;
- jumping.lastStartTime = Time.time;
- jumping.lastButtonDownTime = -;
- jumping.holdingJumpButton = true;
- // Calculate the jumping direction
- if (TooSteep())
- jumping.jumpDir = Vector3.Slerp(Vector3.up, groundNormal, jumping.steepPerpAmount);
- else
- jumping.jumpDir = Vector3.Slerp(Vector3.up, groundNormal, jumping.perpAmount);
- // Apply the jumping force to the velocity. Cancel any vertical velocity first.
- velocity.y = ;
- velocity += jumping.jumpDir * CalculateJumpVerticalSpeed(jumping.baseHeight);
- // Apply inertia from platform
- if (movingPlatform.enabled &&
- (movingPlatform.movementTransfer == MovementTransferOnJump.InitTransfer ||
- movingPlatform.movementTransfer == MovementTransferOnJump.PermaTransfer)
- )
- {
- movement.frameVelocity = movingPlatform.platformVelocity;
- velocity += movingPlatform.platformVelocity;
- }
- SendMessage("OnJump", SendMessageOptions.DontRequireReceiver);
- }
- else
- {
- jumping.holdingJumpButton = false;
- }
- }
- return velocity;
- }
- void OnControllerColliderHit(ControllerColliderHit hit)
- {
- if (hit.normal.y > && hit.normal.y > groundNormal.y && hit.moveDirection.y < )
- {
- if ((hit.point - movement.lastHitPoint).sqrMagnitude > 0.001 || lastGroundNormal == Vector3.zero)
- groundNormal = hit.normal;
- else
- groundNormal = lastGroundNormal;
- movingPlatform.hitPlatform = hit.collider.transform;
- movement.hitPoint = hit.point;
- movement.frameVelocity = Vector3.zero;
- }
- }
- private IEnumerable SubtractNewPlatformVelocity()
- {
- // When landing, subtract the velocity of the new ground from the character's velocity
- // since movement in ground is relative to the movement of the ground.
- if (movingPlatform.enabled &&
- (movingPlatform.movementTransfer == MovementTransferOnJump.InitTransfer ||
- movingPlatform.movementTransfer == MovementTransferOnJump.PermaTransfer)
- )
- {
- // If we landed on a new platform, we have to wait for two FixedUpdates
- // before we know the velocity of the platform under the character
- if (movingPlatform.newPlatform)
- {
- var platform = movingPlatform.activePlatform;
- yield return new WaitForFixedUpdate();
- yield return new WaitForFixedUpdate();
- if (grounded && platform == movingPlatform.activePlatform)
- yield return ;
- }
- movement.velocity -= movingPlatform.platformVelocity;
- }
- }
- private bool MoveWithPlatform()
- {
- return movingPlatform.enabled
- && (grounded || movingPlatform.movementTransfer == MovementTransferOnJump.PermaLocked)
- && movingPlatform.activePlatform != null;
- }
- private Vector3 GetDesiredHorizontalVelocity()
- {
- // Find desired velocity
- var desiredLocalDirection = tr.InverseTransformDirection(inputMoveDirection);
- var maxSpeed = MaxSpeedInDirection(desiredLocalDirection);
- if (grounded)
- {
- // Modify max speed on slopes based on slope speed multiplier curve
- var movementSlopeAngle = Mathf.Asin(movement.velocity.normalized.y) * Mathf.Rad2Deg;
- maxSpeed *= movement.slopeSpeedMultiplier.Evaluate(movementSlopeAngle);
- }
- return tr.TransformDirection(desiredLocalDirection * maxSpeed);
- }
- private Vector3 AdjustGroundVelocityToNormal(Vector3 hVelocity, Vector3 groundNormal)
- {
- var sideways = Vector3.Cross(Vector3.up, hVelocity);
- return Vector3.Cross(sideways, groundNormal).normalized * hVelocity.magnitude;
- }
- private bool IsGroundedTest()
- {
- return groundNormal.y > 0.01;
- }
- float GetMaxAcceleration(bool grounded)
- {
- return grounded ? movement.maxGroundAcceleration : movement.maxAirAcceleration;
- }
- float CalculateJumpVerticalSpeed(float targetJumpHeight)
- {
- // From the jump height and gravity we deduce the upwards speed
- // for the character to reach at the apex.
- return Mathf.Sqrt( * targetJumpHeight * movement.gravity);
- }
- bool IsJumping()
- {
- return jumping.jumping;
- }
- bool IsSliding()
- {
- return (grounded && sliding.enabled && TooSteep());
- }
- bool IsTouchingCeiling()
- {
- return (movement.collisionFlags & CollisionFlags.CollidedAbove) != ;
- }
- bool IsGrounded()
- {
- return grounded;
- }
- bool TooSteep()
- {
- return (groundNormal.y <= Mathf.Cos(controller.slopeLimit * Mathf.Deg2Rad));
- }
- Vector3 GetDirection()
- {
- return inputMoveDirection;
- }
- void SetControllable(bool controllable)
- {
- canControl = controllable;
- }
- // Project a direction onto elliptical quater segments based on forward, sideways, and backwards speed.
- // The function returns the length of the resulting vector.
- float MaxSpeedInDirection(Vector3 desiredMovementDirection)
- {
- if (desiredMovementDirection == Vector3.zero)
- return ;
- else
- {
- var zAxisEllipseMultiplier = (desiredMovementDirection.z > ? movement.maxForwardSpeed : movement.maxBackwardsSpeed) / movement.maxSidewaysSpeed;
- var temp = new Vector3(desiredMovementDirection.x, , desiredMovementDirection.z / zAxisEllipseMultiplier).normalized;
- var length = new Vector3(temp.x, , temp.z * zAxisEllipseMultiplier).magnitude * movement.maxSidewaysSpeed;
- return length;
- }
- }
- void SetVelocity(Vector3 velocity)
- {
- grounded = false;
- movement.velocity = velocity;
- movement.frameVelocity = Vector3.zero;
- SendMessage("OnExternalVelocity");
- }
- }
Unity 之 c# 版的 CharacterMotor的更多相关文章
- [Unity+Android]横版扫描二维码
原地址:http://blog.csdn.net/dingxiaowei2013/article/details/25086835 终于解决了一个忧伤好久的问题,严重拖了项目进度,深感惭愧!一直被一系 ...
- Unity 3D 文件导入出错误解决方法以及unity圣典离线版下载地址
1.安装unity 时我选择了free版的,打开已有项目时出现如下错误提示. 解决方法:先把要导入的文件先拷贝到unity3d安装目录下对应的文件夹内,之后再返回unity3d软件,右键选择“导入”. ...
- 关于Unity中旧版动画系统的使用
Unity在5.X以后,有一个旧版的动画系统和新版的动画系统. 新版的动画系统是使用Unity动画编辑器来调的,调动画和控制动画 旧版的动画系统是用其他的第三方软件调好后导出到一个FBX文件里面,就是 ...
- unity, 查看build版log文件
http://blog.theknightsofunity.com/accessing-unity-game-logs/
- Unity 5 引擎收费版和免费版的区别(转)
最新Unity 5的Professional Edition(收费版)具备全新而强大的功能,除了全局动态光照或是最新的基于物理的着色器之外,也把原本分开销售的Team License放入,并含有12个 ...
- 命令行构建Unity项目
自动任务构建 通常可以在桌面双击 Unity 图标,启动程序,但是,也可以通过命令行(例如,MacOS 终端或 Windows Command 窗口)运行程序.若使用这种方式启动 Unity,它将可以 ...
- 通过Unity3D发布IOS版游戏
https://developer.apple.com/ 打开上面的苹果开发者网站,选择上面的"Member Center"登录进入.前提是,你注册了开发者账号,并且付了年费. 选 ...
- Unity ECS 视频笔记
视频摘要 本文视频资料:使用Entity Component System开发<快乐的Minecraft>游戏 使用Unity2018及以上版本才有ECS功能. 本文是看视频的一些摘要. ...
- 【Unity】1.1 安装Unity 5.3.4 开发环境
分类:Unity.C#.VS2015 创建日期:2016-03-23 一.简介 Unity分个人版(Personal)和专业版(Pro).个人版是免费的(部分高级功能受限,但初学者也用不到它),Pro ...
随机推荐
- bjective-C 中核心处理字符串的类是 NSString 与 NSMutableString
Objective-C 中核心处理字符串的类是 NSString 与 NSMutableString ,这两个类最大的区别就是NSString 创建赋值以后该字符串的内容与长度不能在动态的更改,除非重 ...
- linux 查看 cpu 和内存的命令 - top
1.查看内存,cpu ,当前进程task数目, 每个进程的cpu, 内存使用率, 用top 命令: 在这个页面,按 P,下面的进程排序,以cpu使用率降序排列. 按M,按内存使用率降序排列: 按N, ...
- 由浅到深理解java反射
1.基础概念 class类: 1.1java是面向对象的,但是在java中存在两种东西不是面向对象的 一种是普通的数据类型,这也是封装数据类存在的原因. 二种是静态静态成员. 1.2所以我们首先要理解 ...
- JS动态引入js、CSS动态创建script/link/style标签
一.动态创建link方式 我们可以使用link的方式.如下代码所示. function addCssByLink(url){ var doc=document; var link=doc.create ...
- python注意事项
以下基于python3.4.3 1.python3与python2不兼容 2.python语言正确的缩进很重要!事实上缩进是种语法 C中需要 { } 的的地方,python使用 : +缩进 实现 3. ...
- HUD 1541/BIT(数状数组)
题目链接 /* 按从左到右,从下到上的顺序给出星星的坐标,计算出level为[0,n)的星星的个数. 星星的level为该星星左下边(包括自己正下方的星星,但是不包括自己)星星的个数. BIT模板题. ...
- HDU 1072/BFS
题目链接 Nightmare Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Tota ...
- angular.js简介
angularJS是一个javaScript框架.可通过<script>标签添加到HTML页面 angular通过指令扩展了HTML,且通过表达式绑定数据到html 当网页加载完毕,Ang ...
- FileReader和BufferedReader的区别
1.FileReader不能一行行读 FileReader fr = null; try { fr = new FileReader(new File(path)); StringBuffer str ...
- docker rmi all
docker stop $(docker ps -a -q) docker rm $(docker ps -a -q)