- 浏览: 1090622 次
- 性别:
- 来自: 杭州
-
文章分类
- 全部博客 (695)
- 心情日记 (14)
- AS开发工具 (12)
- 文章转载 (99)
- AIR (5)
- 问题总结 (46)
- SWF格式 (7)
- 测试总结 (10)
- 外文资料 (9)
- 算法技术 (33)
- AS3常用开源库 (43)
- 源码范例 (102)
- FLEX (72)
- FLASH 优化 (33)
- 游戏开发 (49)
- 开发技术 (11)
- 工作应用 (34)
- AS3收集 (140)
- WebBase (0)
- 开发构想 (4)
- 设计模式 (2)
- 框架和框架范例 (19)
- RED5 (3)
- java开发 (3)
- JAVA (1)
- FLASH-3D (23)
- 3D (6)
- 书籍 (10)
- 业界信息资料 (3)
- C# (1)
- JavaScript (12)
- HTML5 (6)
- Flixel (1)
- D5Power RPG网页游戏引擎 (0)
- ColorMatrixFilter - 获得相应颜色的色调 函数 (0)
- Starling (0)
最新评论
-
老顽童203:
字体
水果忍者鼠标跟随特效制作[转载] -
hairball00:
[转] 放出超多的Flash组件源代码 -
he74552775:
flash AS3 RegExp简单功能用法(转) -
hanshuai1232000:
第四点,有利也有弊,等你做了大型的aprg,你就知道了
[转]位图数据内存优化 -
yangfantao:
太感谢
[转] 放出超多的Flash组件源代码
第二个是书中的源代码给出了一个Collision类,其中的block方法可以实现两个物体之间的碰撞检测。
有趣的是,Collsion.block方法有两个参数,第一个是被阻碍物,第二个是障碍物,在这个演示中,山上有两块石板。
对于左边的石板,石板是被阻碍物,小猪是障碍物,产生的效果就是小猪可以推着石板走。
对于右边的石板,小猪是被阻碍物,石板是障碍物,产生的效果就是小猪撞到墙上就不能动了,很有意思。
http://bbs.9ria.com/viewthread.php?tid=88769&extra=page%3D1%26amp%3Borderby%3Ddateline%26amp%3Bfilter%3D2592000
package |
{ |
import flash.display.MovieClip; |
import flash.geom.Point; |
|
public class Collision |
//0.2 (March 20, 2009) |
{ |
public function Collision() |
{ |
} |
|
//Block objects |
static public function block(objectA:MovieClip, objectB:MovieClip):void |
{ |
var objectA_Halfwidth:Number = objectA.width / 2; |
var objectA_Halfheight:Number = objectA.height / 2; |
var objectB_Halfwidth:Number = objectB.width / 2; |
var objectB_Halfheight:Number = objectB.height / 2; |
var dx:Number = objectB.x - objectA.x; |
var ox:Number = objectB_Halfwidth
+ objectA_Halfwidth - Math.abs(dx); |
if (ox > 0) |
{ |
var dy:Number = objectA.y - objectB.y; |
var oy:Number = objectB_Halfheight
+ objectA_Halfheight - Math.abs(dy); |
if (oy > 0) |
{ |
if (ox < oy) |
{ |
if (dx < 0) |
{ |
//Collision on right |
oy = 0; |
} |
else |
{ |
//Collision on left |
oy = 0; |
ox *= -1; |
} |
} |
else |
{ |
if (dy < 0) |
{ |
//Collision on Top |
ox = 0; |
oy *= -1; |
} |
else |
{ |
//Collision on Bottom |
ox = 0; |
} |
} |
|
//Use the
calculated x and y overlaps to |
//Move objectA
out of the collision |
|
objectA.x += ox; |
objectA.y += oy; |
} |
} |
} |
|
//General purpose method for
testing Axis-based collisions. Returns true or False |
static public function test(objectA:Object,objectB:Object):Boolean |
{ |
var objectA_Halfwidth=objectA.width/2; |
var objectA_Halfheight=objectA.height/2; |
var objectB_Halfwidth=objectB.width/2; |
var objectB_Halfheight=objectB.height/2; |
var dx=objectB.x-objectA.x; |
var ox=objectB_Halfwidth+objectA_Halfwidth-Math.abs(dx); |
if (0<ox) |
{ |
var dy=objectA.y-objectB.y; |
var oy=objectB_Halfheight+objectA_Halfheight-Math.abs(dy); |
if (0<oy) |
{ |
return true; |
} |
} |
else |
{ |
return false; |
} |
return false; |
} |
|
//Collisions between the
player and platform |
static public function playerAndPlatform(player:MovieClip,
platform:MovieClip, bounce:Number,
friction:Number):void |
{ |
//This method requires the
following getter and |
//setter properties in the
player object: |
//objectIsOnGround:Boolean,
vx:Number, vy:Number, |
//bounceX:Number,
bounceY:Number |
|
//Decalre variables needed
for the player's |
//position and
dimensions |
var player_Halfwidth:Number; |
var player_Halfheight:Number; |
var player_X:Number; |
var player_Y:Number |
|
//Decalre variables needed
for the physics calculations |
var bounceX:Number; |
var bounceY:Number; |
var frictionX:Number; |
var frictionY:Number; |
|
//Find out whether the player
object has a collisionArea |
//subobject
defined |
if(player.collisionArea
!= null) |
{ |
//If it does, find out
its width and height |
player_Halfwidth = player.collisionArea.width / 2; |
player_Halfheight = player.collisionArea.height / 2; |
|
//Convert the
collisionArea's local x,y coordinates to global coordinates |
var player_Position:Point = new Point(player.collisionArea.x, player.collisionArea.y); |
player_X
= player.localToGlobal(player_Position).x; |
player_Y = player.localToGlobal(player_Position).y; |
} |
else |
{ |
//If there's no
collisionArea subobject |
//Use the player's main
height, width, x and y |
player_Halfwidth = player.width / 2; |
player_Halfheight = player.height / 2; |
player_X = player.x; |
player_Y = player.y; |
} |
//Find the platform's
dimensions |
var platform_Halfwidth:Number =
platform.width / 2; |
var platform_Halfheight:Number =
platform.height / 2; |
|
//Find the distance between
the player and platfrom on the x axis |
var dx:Number =
platform.x -
player_X; |
|
//Find the amount of overlap
on the x axis |
var ox:Number = platform_Halfwidth
+ player_Halfwidth - Math.abs(dx); |
|
//Check for a collision on
the x axis |
if (ox > 0) |
{ |
//If the objects
overlap on the x axis, a collision might be occuring |
//Define the variables
you need to check for a collision on the y axis |
var dy:Number = player.y - platform.y; |
var oy:Number = platform_Halfheight
+ player_Halfheight - Math.abs(dy); |
|
//Check for a y axis
collision. We know a collision must be |
//occuring if there's a
collision on both the x and y axis |
if (oy > 0) |
{ |
//Yes, a
collision is occuring! |
//Now you need
to find out on which side |
//of the
platform it's occuring on. |
if (ox < oy) |
{ |
if (dx < 0) |
{ |
//Collision on right |
oy = 0; |
dx = 1; |
dy = 0 |
} |
else |
{ |
//Collision on left |
oy = 0; |
ox *= -1; |
dx = -1; |
dy = 0 |
} |
} |
else |
{ |
if (dy < 0) |
{ |
//Collision on Top |
ox = 0; |
oy *= -1; |
dx = 0; |
dy = -1; |
//set the player's isOnGround property to |
//true to enable jumping |
player.isOnGround
= true; |
} |
else |
{ |
//Collision on Bottom |
ox = 0; |
dx = 0; |
dy = 1; |
} |
} |
|
//Find the
direction of the collision ("dot product") |
var directionOfCollision:Number = player.vx * dx + player.vy * dy; |
|
//Calculate the
new direction for the bounce ("projection") |
var newDirection_X:Number =
directionOfCollision * dx; |
var newDirection_Y:Number =
directionOfCollision * dy; |
|
//Find the
"tangent velocity": |
//the speed in
the direction that the object is moving. |
//It's used for
calculating additional platform friction. |
var tangent_Vx:Number = player.vx - newDirection_X; |
var tangent_Vy:Number = player.vy - newDirection_Y; |
|
//Apply
collision forces if the object is moving into a collision |
if (directionOfCollision
< 0) |
{ |
//Calculate the friction |
frictionX = tangent_Vx
* friction; |
frictionY = tangent_Vy
* friction; |
|
//Calculate the amount of bounce |
bounceX = newDirection_X
* bounce; |
bounceY = newDirection_Y
* bounce; |
} |
else |
{ |
//Prevent forces from being applied if the object is |
//moving out of a collision |
bounceX = 0; |
bounceY = 0; |
frictionX = 0; |
frictionY = 0; |
} |
//Apply
platform friction |
player.vx += ox - frictionX; |
player.vy += oy - frictionY; |
|
//Move the
player out of the collision |
player.x += ox; |
player.y += oy; |
|
//Bounce the
player off the platform |
player.bounceX = bounceX; |
player.bounceY = bounceY; |
} |
} |
} |
} |
} |
发表评论
-
greenSock新老库
2012-08-07 13:25 0老库-做项目的时候比新库完全不抖啊 -
Starling开发的游戏源码
2012-07-26 17:13 0Starling开发的游戏源码 -
一个基于STARLING的TOWER塔防游戏
2012-07-24 15:27 0一个基于STARLING的TOWER塔防游戏 -
HttpStatusConfig --一个HTTP 协议返回的 解析说明类
2012-04-18 16:40 0package guwanyuan.qicool.game ... -
[转] [Flash/Flex] 加载SWF性能VS影片剪辑性能
2012-03-15 22:29 0http://bbs.9ria.com/viewthread. ... -
水果忍者鼠标跟随特效制作[转载]
2012-03-01 16:06 2467实现这效果其实比较简单,主要是思路~! package ... -
greensock-as3
2012-02-23 21:26 0greensock-as3 -
禁止输入文本可以粘贴
2012-02-10 13:15 2330//禁止输入文本粘贴动作 private static ... -
江湖情缘游戏里的跳的类
2012-02-08 23:55 0package com.app.role.montions ... -
ColorMatrixFilter - 获得相应颜色的色调 函数
2012-02-08 23:03 0/**获得相应颜色的色调的滤镜**/ public sta ... -
[教程] 路点导航(Waypoint Navigation)
2011-12-31 00:51 0前言:这个不难,所以知道的童鞋不要喷,不知道的童鞋也不要怕,要 ... -
ARPG游戏引擎设计思路
2011-12-31 00:48 00.整体结构 下载 (32.92 KB ... -
Embed绑定XML与txt文本文件
2011-12-28 15:54 4667使用Embed标签可以将图片绑定到swf中并显示,那么我 ... -
弹弹堂测试
2011-12-08 04:21 0弹弹堂测试弹弹堂测试 -
一些DEMO
2011-11-28 17:42 0一些DEMO一些DEMO -
[转]三次贝尔曲线
2011-11-10 01:09 1939http://bbs.9ria.com/viewt ... -
[心得] 完美解决as3在ie中初始化时stageWidth和stageHeight为0的问题
2011-11-03 00:46 2953先看下面的一段脚本,这是比较经典的初始化脚本: pa ... -
五子棋算法详解
2011-10-31 04:14 0五子棋算法详解五子棋算法详解五子棋算法详解 -
[转]服务器端ActionScript语言参考
2011-10-31 00:29 0服务器端ActionScript语言参考 -
[转]FLASH与JS序列简单应用
2011-10-28 01:03 2104FLASH与JS序列简单应用 (一) 用swfob ...
相关推荐
虚幻4游戏开发系列课程中,第七十一课主要讲解了两个关键知识点:碰撞(Collision)机制和创建可拾取物品的实现方法。 首先,碰撞(Collision)是游戏开发中至关重要的一个部分,它使得游戏中的对象能够根据物理规则...
凸面物体的一个显著特点是其任何两个点之间的连线都在物体内部或者边界上。例如,一个球体就是一个典型的凸面物体。 凸面物体在游戏引擎中的一个重要应用是碰撞检测算法。由于其几何特性,凸面物体能够更高效地进行...
deepseek最新资讯、配置方法、使用技巧,持续更新中
Heric拓扑并网离网仿真模型:PR单环控制,SogIPLL锁相环及LCL滤波器共模电流抑制技术解析,基于Heric拓扑的离网并网仿真模型研究与应用分析:PR单环控制与Sogipll锁相环的共模电流抑制效能,#Heric拓扑并离网仿真模型(plecs) 逆变器拓扑为:heric拓扑。 仿真说明: 1.离网时支持非单位功率因数负载。 2.并网时支持功率因数调节。 3.具有共模电流抑制能力(共模电压稳定在Udc 2)。 此外,采用PR单环控制,具有sogipll锁相环,lcl滤波器。 注:(V0004) Plecs版本4.7.3及以上 ,Heric拓扑; 离网仿真; 并网仿真; 非单位功率因数负载; 功率因数调节; 共模电流抑制; 共模电压稳定; PR单环控制; sogipll锁相环; lcl滤波器; Plecs版本4.7.3及以上,Heric拓扑:离网并网仿真模型,支持非单位功率因数与共模电流抑制
2024免费微信小程序毕业设计成品,包括源码+数据库+往届论文资料,附带启动教程和安装包。 启动教程:https://www.bilibili.com/video/BV1BfB2YYEnS 讲解视频:https://www.bilibili.com/video/BV1BVKMeZEYr 技术栈:Uniapp+Vue.js+SpringBoot+MySQL。 开发工具:Idea+VSCode+微信开发者工具。
基于SMIC 40nm工艺库的先进芯片技术,SMIC 40nm工艺库技术细节揭秘:引领半导体产业新革命,smic40nm工艺库 ,smic40nm; 工艺库; 芯片制造; 纳米技术,SMIC 40nm工艺库:领先技术驱动的集成电路设计基础
2013年上半年软件设计师上午题-真题及答案解析
shp格式,可直接导入arcgis使用
ROS下的移动机器人路径规划算法:基于强化学习算法DQN、DDPG、SAC及TD3的实践与应用,ROS系统中基于强化学习算法的移动机器人路径规划策略研究:应用DQN、DDPG、SAC及TD3算法,ROS下的移动机器人路径规划算法,使用的是 强化学习算法 DQN DDPG SAC TD3等 ,ROS; 移动机器人; 路径规划算法; DQN; DDPG; SAC; TD3,ROS强化学习移动机器人路径规划算法研究
粒子群优化算法精准辨识锂电池二阶RC模型参数:高仿真精度下的SOC估计铺垫,粒子群优化算法精准辨识锂电池二阶RC模型参数:仿真验证与SOC估计铺垫,使用粒子群优化算法(PSO)辨识锂电池二阶RC模型参数(附MATLAB代码) 使用粒子群优化算法来辨识锂离子电池二阶RC模型的参数。 将粒子群优化算法寻找到的最优参数代入二阶RC模型进行仿真,经过验证,端电压的估计误差小于0.1%,说明粒子群优化算法辨识得到的参数具有较高的精度,为锂离子电池SOC的估计做铺垫。 ,关键词:粒子群优化算法(PSO); 锂电池二阶RC模型参数辨识; MATLAB代码; 端电压估计误差; 锂离子电池SOC估计。,PSO算法优化锂电池二阶RC模型参数:高精度仿真与MATLAB代码实现
selenium环境搭建-谷歌浏览器驱动
在当今科技日新月异的时代,智慧社区的概念正悄然改变着我们的生活方式。它不仅仅是一个居住的空间,更是一个集成了先进科技、便捷服务与人文关怀的综合性生态系统。以下是对智慧社区整体解决方案的精炼融合,旨在展现其知识性、趣味性与吸引力。 一、智慧社区的科技魅力 智慧社区以智能化设备为核心,通过综合运用物联网、大数据、云计算等技术,实现了社区管理的智能化与高效化。门禁系统采用面部识别技术,让居民无需手动操作即可轻松进出;停车管理智能化,不仅提高了停车效率,还大大减少了找车位的烦恼。同时,安防报警系统能够实时监测家中安全状况,一旦有异常情况,立即联动物业进行处理。此外,智能家居系统更是将便捷性发挥到了极致,通过手机APP即可远程控制家中的灯光、窗帘、空调等设备,让居民随时随地享受舒适生活。 视频监控与可视对讲系统的结合,不仅提升了社区的安全系数,还让居民能够实时查看家中情况,与访客进行视频通话,大大增强了居住的安心感。而电子巡更、公共广播等系统的运用,则进一步保障了社区的治安稳定与信息传递的及时性。这些智能化设备的集成运用,不仅提高了社区的管理效率,更让居民感受到了科技带来的便捷与舒适。 二、智慧社区的增值服务与人文关怀 智慧社区不仅仅关注科技的运用,更注重为居民提供多元化的增值服务与人文关怀。社区内设有互动LED像素灯、顶层花园控制喷泉等创意设施,不仅美化了社区环境,还增强了居民的归属感与幸福感。同时,社区还提供了智能家居的可选追加项,如空气净化器、远程监控摄像机等,让居民能够根据自己的需求进行个性化选择。 智慧社区还充分利用大数据技术,对居民的行为数据进行收集与分析,为居民提供精准化的营销服务。无论是周边的商业信息推送,还是个性化的生活建议,都能让居民感受到社区的智慧与贴心。此外,社区还注重培养居民的环保意识与节能意识,通过智能照明、智能温控等系统的运用,鼓励居民节约资源、保护环境。 三、智慧社区的未来发展与无限可能 智慧社区的未来发展充满了无限可能。随着技术的不断进步与创新,智慧社区将朝着更加智能化、融合化的方向发展。比如,利用人工智能技术进行社区管理与服务,将能够进一步提升社区的智能化水平;而5G、物联网等新技术的运用,则将让智慧社区的连接更加紧密、服务更加高效。 同时,智慧社区还将更加注重居民的体验与需求,通过不断优化智能化设备的功能与服务,让居民享受到更加便捷、舒适的生活。未来,智慧社区将成为人们追求高品质生活的重要选择之一,它不仅是一个居住的空间,更是一个融合了科技、服务、人文关怀的综合性生态系统,让人们的生活更加美好、更加精彩。 综上所述,智慧社区整体解决方案以其科技魅力、增值服务与人文关怀以及未来发展潜力,正吸引着越来越多的关注与认可。它不仅能够提升社区的管理效率与居民的生活品质,更能够为社区的可持续发展注入新的活力与动力。
PowerSettingsExplorer.rar 电脑的电源管理软件,明白的不多说。自己搜索即可知道。
deepseek最新资讯,配置方法,使用技巧,持续更新中
deepseek最新资讯、配置方法、使用技巧,持续更新中
RabbitMQ 是一个开源的消息代理(Message Broker),实现了 AMQP(Advanced Message Queuing Protocol) 协议,用于在分布式系统中实现高效、可靠的消息传递。
西门子S7-1200与汇川PLC新通信选择:Ethernet IP通信的突破与优势,功能安全及精准同步的创新实践。,西门子S7-1200与汇川PLC通信新选择:Ethernet IP通信方案亮相,替代Modbus TCP实现更高级功能与安全控制。,西门子PLC和汇川PLC新通信选择-西门子S7-1200 1500系列PLC也开始支持Ethernet IP通信了。 这为西门子系列的PLC和包括汇川AM400 600等Codesys系PLC的通信提供了新的解决方案。 当前两者之间的通信大多采用ModBus TCP通信。 Modbus TCP和EtherNet IP的区别主要是应用层不相同,ModbusTCP的应用层采用Modbus协议,而EtherNetIP采用CIP协议,这两种工业以太网的数据链路层采用的是CSMACCD,因此是标准的以太网,另外,这两种工业以太网的网络层和传输层采用TCPIP协议族。 还有一个区别是,Modbus协议中迄今没有协议来完成功能安全、高精度同步和运功控制等,而EtherNet IP有CIPSatety、ClIP Sync和ClPMotion来
自适应无迹卡尔曼滤波AUKF算法:系统估计效果展示与特性分析(含MATLAB代码与Excel数据),自适应无迹卡尔曼滤波AUKF算法:系统估计效果展示与特性分析(含MATLAB代码与Excel数据),自适应无迹卡尔曼滤波AUKF算法 配套文件包含MATLAB代码+excel数据+学习资料 估计效果与系统特性有关,图片展示为一复杂系统估计效果 ,AUKF算法; MATLAB代码; excel数据; 学习资料; 估计效果; 系统特性。,自适应无迹卡尔曼滤波AUKF算法:MATLAB代码与学习资料
基于MATLAB Simscape的IGBT开关特性模型:揭示开关损耗、米勒平台及瞬态行为的分析工具,IGBT开关特性模型与MATLAB Simscape模拟:深入理解开关行为及损耗数据,IGBT开关特性模型,MATLAB Simscape模型。 该模型展示了IGBT的详细的开关模型,用于创建开关损耗列表数据。 有助于理解IGBT米勒平台、瞬态开关行为。 也可以用于MOOSFET。 ,IGBT开关模型; MATLAB Simscape; 开关损耗; 米勒平台; 瞬态开关行为; MOOSFET。,MATLAB Simscape中IGBT精细开关模型:揭示米勒平台与瞬态行为
基于卷积神经网络CNN的多输入单输出数据回归预测——含详细注释与多种评估指标(R2、MAE、MBE),基于卷积神经网络CNN的多输入单输出数据回归预测模型详解——附代码注释、指标评估及Excel数据处理方法,基于卷积神经网络CNN的数据回归预测 多输入单输出预测 代码含详细注释,不负责 数据存入Excel,替方便,指标计算有决定系数R2,平均绝对误差MAE,平均相对误差MBE ,基于卷积神经网络CNN; 数据回归预测; 多输入单输出; 详细注释; Excel存储; 指标计算(R2; MAE; MBE); 不负责。,基于CNN的卷积数据回归预测模型:多输入单输出代码详解与性能评估