查看: 1314|回复: 1
打印 上一主题 下一主题

鼠标拖动物体旋转展示代码

[复制链接]

2508

主题

2

听众

3万

积分

资深设计师

Rank: 7Rank: 7Rank: 7

纳金币
32806
精华
12

最佳新人 活跃会员 热心会员 灌水之王 突出贡献

跳转到指定楼层
楼主
发表于 2012-8-3 17:50:10 |只看该作者 |倒序浏览
应群中一朋友要求,好像要做一个产品展示的效果,即鼠标按下即可扡动物体任意旋转观看的效果,现在实现此效果的js代码列出,供大伙参考下:
var target : Transform;

var distance = 20.0;

var mySpeed = 250.0;

private var x = 0.0;

private var y = 0.0;

var xMinLimit=30;

var xMaxLimit=120;

var yMinLimit=30;

var yMaxLimit=120;
function Start () {

    var angles = transform.eulerAngles;

    x = angles.y;

    y = angles.x;

}
function LateUpdate () {

   if (Input.GetMouseButton(0)){

      x += Input.GetAxis("Mouse X") * mySpeed * 0.02;

      x = ClampAngle(x, xMinLimit, xMaxLimit);

      y -= Input.GetAxis("Mouse Y") * mySpeed * 0.01;

      y = ClampAngle(y, yMinLimit, yMaxLimit);

   }

   var rotation = Quaternion.Euler(y, x, 0);

   transform.rotation = rotation;

   var position = rotation * Vector3(0.0, 0.0, -distance) + target.position;

   transform.position = position;

}
static function ClampAngle (angle : float, min : float, max : float) {

   if (angle < -360)

      angle += 360;

   if (angle > 360)

      angle -= 360;

   return Mathf.Clamp (angle, min, max);

}
代码的具体含义就不在列出了,有需要的朋友可以动手测试下就明白了。
分享到: QQ好友和群QQ好友和群 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
转播转播0 分享淘帖0 收藏收藏0 支持支持0 反对反对0
回复

使用道具 举报

2508

主题

2

听众

3万

积分

资深设计师

Rank: 7Rank: 7Rank: 7

纳金币
32806
精华
12

最佳新人 活跃会员 热心会员 灌水之王 突出贡献

沙发
发表于 2012-8-3 17:53:48 |只看该作者
我爱纳金网~www.narkii.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

手机版|纳金网 ( 闽ICP备2021016425号-2/3

GMT+8, 2025-1-31 21:00 , Processed in 0.062405 second(s), 29 queries .

Powered by Discuz!-创意设计 X2.5

© 2008-2019 Narkii Inc.

回顶部