当前位置:  编程技术>移动开发
本页文章导读:
    ▪Core Animation之基础引见        Core Animation之基础介绍   Core Animation可以翻译为核心动画,它为图形渲染和动画提供了基础。使用核心动画,你只需要设置一些参数比如起点和终点,剩下的帧核心动画为你自动完成。核心.........
    ▪ 基于WiEngine游戏发动机-战斗场景之技能        基于WiEngine游戏引擎--战斗场景之技能 转发,请保持地址:http://blog.csdn.net/stalendp/article/details/8606424 游戏战斗场景中的技能也是游戏的特色之一,这篇文章将记录使用WiEngine来设计游戏中的技.........
    ▪ 查看装置跑的是当前的哪个activity       查看设备跑的是当前的哪个activity 找到sdk的安装路径,比如我的是 D:\Program Files\android-sdk-windows\tools\该路径下的如下工具: hierarchyviewer.bat 双击,可以用此工具查看设备跑的是当前的哪个activi.........

[1]Core Animation之基础引见
    来源: 互联网  发布时间: 2014-02-18
Core Animation之基础介绍

   Core Animation可以翻译为核心动画,它为图形渲染和动画提供了基础。使用核心动画,你只需要设置一些参数比如起点和终点,剩下的帧核心动画为你自动完成。核心动画使用硬件加速,不用消耗cpu资源。其实平时咱们开发的iOS应用都在有意无意的使用了核心动画。动画不会替代View,而是和View一起提供更好的性能。Core Animation通过缓存view上的内容到bitmap,这样bitmap就可以直接在图形硬件上操作。从而提高了性能。

核心动画所在的位置:



1、关于层类

Layer Classes是core animation的基础。Layer Classes提供了一个抽象的概念,这个概念对于那些使用NSview和UIview的开发者来说是很熟悉的。基础层是由CAlayer类提供的,CAlayer是所有Core Animation层的父类。    
同一个视图类的实例一样,一个CAlayer实例也有一个单独的superlayer和上面所有的子层(sublayers),它创建了一个有层次结构的层,我们称之为layer tree。layers的绘制就像views一样是从后向前绘制的,绘制的时候我们要指定其相对与他们的superlayer的集合形状,同时还需要创建一个局部的坐标系。layers可以做一些更复杂的操作,例如rotate(旋转),skew(倾斜),scale(放缩),和project the layer content(层的投影)。   
图层的内容提供
(1)直接设置层的content属性到一个core graphics图,或者通过delegation来设置
(2)提供一个代理直接绘制到Core Graphics image context(核心图形的上下文)
(3)设置任意数量的所有层共有的可视的风格属性。例如:backgroundColor(背景色),opacity(透明度)和masking(遮罩)。max os x应用通过使用core image filters来达到这种可视化的属性。
(4)子类化CAlayer,同时在更多的封装方式中完成上面的任意技术。 

 1.1 CALayer的子类和他们的使用场景

Class

Usage

CAEmitterLayer

Used to implement a Core Animation–based particle emitter system. The emitter layer object controls the generation of the particles and their origin.

CAGradientLayer

Used to draw a color gradient that fills the shape of the layer (within the bounds of any rounded corners).

CAEAGLLayer/CAOpenGLLayer

Used to set up the backing store and context needed to draw using OpenGL ES (iOS) or OpenGL (OS X).

CAReplicatorLayer

Used when you want to make copies of one or more sublayers automatically. The replicator makes the copies for you and uses the properties you specify to alter the appearance or attributes of the copies.

CAScrollLayer

Used to manage a large scrollable area composed of multiple sublayers.

CAShapeLayer

Used to draw a cubic Bezier spline. Shape layers are advantageous for drawing path-based shapes because they always result in a crisp path, as opposed to a path you draw into a layer’s backing store, which would not look as good when scaled. However, the crisp results do involve rendering the shape on the main thread and caching the results.

CATextLayer

Used to render a plain or attributed string of text.

CATiledLayer

Used to manage a large image that can be divided into smaller tiles and rendered individually with support for zooming in and out of the content.

CATransformLayer

Used to render a true 3D layer hierarchy, rather than the flattened layer hierarchy implemented by other layer classes.

QCCompositionLayer

Used to render a Quartz Composer composition. (OS X only)

1.2、 anchorPoint、 position

anchorPoint又称锚点,锚点对动画是有很大影响的。下图描述了基于锚点的三个示例值:



1.3、 图层的 frame、bounds、position 和 anchorPoint 关系如下图所示: 


在该示例中,anchorPoint 默认值为(0.5,0.5),位于图层的中心点。图层的 position 值为(100.0,100.0),bounds 为(0.0,0.0,120,80.0)。通过计算得到图层的 frame为(40.0,60.0,120.0,80.0)。

如果你新创建一个图层,则只有设置图层的 frame 为(40.0,60.0,120.0,80.0),相应的 position 属性值将会自动设置为(100.0,100.0),而 bounds 会自动设置为 (0.0,0.0,120.0,80.0)。下图显示一个图层具有相同的 frame(如上图),但是在该图中它的 anchorPoint 属性值被设置为(0.0,0.0),位于图层的左下角位置。


图层的 frame 值同样为(40.0,60.0,120.0,80.0),bounds 的值不变,但是图层的 position 值已经改变为(40.0,60.0)。


2、关于动画类

核心动画的动画类使用基本的动画和关键帧动画把图层的内容和选取的属性动画的显示出来。所有核心动画的动画类都是从 CAAnimation 类继承而来。
CAAnimation 实现了 CAMediaTiming 协议,提供了动画的持续时间,速度,和重复计数。 CAAnimation 也实现了 CAAction 协议。该协议为图层触发一个动画动作提供了提供标准化响应。动画类同时定义了一个使用贝塞尔曲线来描述动画改变的时间函数。例如,一个 匀速时间函数(linear timing function)在动画的整个生命周期里面一直保持速度不变, 而渐缓时间函数(ease-out timing function)则在动画接近其生命周期的时候减慢速度。核心动画额外提供了一系列抽象的和细化的动画类,比如:CATransition 提供了一个图层变化的过渡效果,它能影响图层的整个内容。 动画进行的时候淡入淡出(fade)、推(push)、显露(reveal)图层的内容。这些过渡效 果可以扩展到你自己定制的 Core Image 滤镜。CAAnimationGroup 允许一系列动画效果组合在一起,并行显示动画。

2.1动画类

 CAPropertyAnimation :是一个抽象的子类,它支持动画的显示图层的关键路 径中指定的属性一般不直接使用,而是使用它的子类,CABasicAnimation,CAKeyframeAnimation. 在它的子类里修改属性来运行动画。
CABasicAnimation: 简单的为图层的属性提供修改。 很多图层的属性修改默认会执行这个动画类。比如大小,透明度,颜色等属性
 CAKeyframeAnimation: 支持关键帧动画,你可以指定的图层属性的关键路径动画,包括动画的每个阶段的价值,以及关键帧时间和计时功能的一系列值。在 动画运行是,每个值被特定的插入值替代。核心动画 和 Cocoa Animation 同时使用这些动画类。

2.2 如何使用多个动画效果叠加

在执行动画的过程中需要同时修改position,alpha, frame等属性,使用CAAnimationGroup可以将三个动画合成一起执行:

CAAnimationGroup *animGroup = [CAAnimationGroup animation]; 
animGroup.animations = [NSArray arrayWithObjects:moveAnim,scaleAnim,opacityAnim, nil];
animGroup.duration = 1;
[view.layer addAnimation:animGroup forKey:nil];

2.3事务管理类  

   图层的动画属性的每一个修改必然是事务的一个部分。CATransaction 是核心动画里面负责协调多个动画原子更新显示操作。事务支持嵌套使用。 


2.4 Core Animation类的继承关系图 


看完这篇可以实验下CALayer的使用了:Core Animation之简单使用CALayer
还有: Core Animation之多种动画效果

容芳志 (http://blog.csdn.net/totogo2010)

本文遵循“署名-非商业用途-保持一致”创作公用协议


    
[2] 基于WiEngine游戏发动机-战斗场景之技能
    来源: 互联网  发布时间: 2014-02-18
基于WiEngine游戏引擎--战斗场景之技能

转发,请保持地址:http://blog.csdn.net/stalendp/article/details/8606424

游戏战斗场景中的技能也是游戏的特色之一,这篇文章将记录使用WiEngine来设计游戏中的技能及其按钮特效。

先看效果图吧:

点击技能的按钮,就会放出技能。技能有冷却事件,表现在按钮上(下图更清晰一些)。


这里的技能用到的是WiEngine粒子系统中的特效。我的理解,粒子系统是一个标准,只要给定相应的参数,就可以显示一些很炫的效果。我本来是想用ParticleDesigner来设计粒子效果的,不过试了一下,发现载入有些问题,所以改用WiEngine中内置的特效了。我这里使用的是官方例子的Meteor(位于Demo/ParticleDemon.h中;补充一下WiEngine的好处,引擎中例子特别详细,我这个demo中的大部分代码都是从例子中改过来的)。我对Meteor进行了一个改进,代码如下:

class ParticleMeteorSystem: public wyQuadParticleSystem {
public:
	ParticleMeteorSystem() :
			wyQuadParticleSystem(150) {
		// duration
		setDuration(PARTICLE_DURATION_INFINITY);

		// gravity
		setParticleGravity(DP(-133.33f), DP(0.33f));

		// angle
		setDirectionAngleVariance(90, 360);

		// speed of particles
		setSpeedVariance(DP(10), DP(3.33f));

		// life of particles
		setLifeVariance(2, 1);

		// size, in pixels
		setStartSizeVariance(DP(40.0f), DP(6.6f));

		// emits per second
		setEmissionRate(getMaxParticles() / getLife());

		// color of particles
		setStartColorVariance(0.2f, 0.4f, 0.7f, 1.0f, 0.0f, 0.0f, 0.2f, 0.1f);
		setEndColorVariance(0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f, 0.0f, 0.0f);

		//set texture
		setTexture(wyTexture2D::makePNG(RES("R.drawable.fire")));

		// additive
		setBlendAdditive(true);
	}
};

class FightBullet: public wyLayer {
private:
	ParticleMeteorSystem* data;
public:
	FightBullet(float px, float py) {
		data = new ParticleMeteorSystem();
		data->autoRelease();
		addChildLocked(data);
		setScale(0.6f);
		setPosition(px, py);
	}

	virtual ~FightBullet() {
	}
};
这里对子弹射击,只是用于演示有些特效的,并没有处理碰撞监测相关的内容(会在接下来的介绍Box2d时讨论),这里使用动画来演示子弹飞行、击中物体,然后使其爆炸的特效。代码如下:

void Boy::shot() {
	wyCallFunc* sbegin = wyCallFunc::make(wyTargetSelector::make(this, SEL(Boy::shotBegin)));
	wyCallFunc* bulletfly = wyCallFunc::make(wyTargetSelector::make(this, SEL(Boy::letBulletFlying)));
	wySequence* s = wySequence::make(sbegin, bulletfly,  NULL);
	sprite->runAction(s);
}

void Boy::shotBegin() {
	LOGI("Shot begin");
	hitBullet = new FightBullet(sprite->getPositionX()-60, sprite->getPositionY()-50);
	addChildLocked(hitBullet);

	sprite->runAction(boyActions[Boy::BOY_HIT]); //让Hero进行攻击的动画
	playEffect(Boy::BOY_HIT); //播放攻击时的音效
}
void Boy::letBulletFlying() {
	LOGI("Shotting");

	wyActionCallback callback = { NULL, onMoveEnd, NULL }; 
	wyMoveBy* moveby = wyMoveBy::make(3, 235, 0);
	moveby->setCallback(&callback, this);
	hitBullet->runAction(moveby);  // 子弹飞行中
}
static void onMoveEnd(wyAction* action, void* data) { // 子弹飞行完,停止射击动画
	Boy* b = (Boy*)data;b->shotEnd();
}
void Boy::shotEnd() {
	LOGI("Shot end");
	changeAction(Boy::BOY_RUN); //子弹飞行完之后,让Hero进行奔跑动画
	removeChild(hitBullet, true);
	hitBullet->release();
	scene->enemyKilled(); // 表明击中物体,这里应当使用碰撞监测的。
}

接下来介绍技能按钮的实现。技能按钮有个冷却的时间(常识啊),在这里我将实现这个效果。相同的技能要准备两张图片,一张明亮一点的,表明技能可以使用,一张暗一点的,表示技能需要冷却。技能冷却时,吧暗一点的图片覆盖在亮一点的图片上, 播放一个动画时暗图片逐渐消失,就达到冷却效果了(效果在上面的第二张图片上很清晰。技能冷却的效果,对于玩过魔兽世界的同学来说,这是理所当然了)。 

OK,附上代码:

class Button2: public wyNode {
public:
	MyScene* scene;
	wyButton* button;
	wySprite* enable;
	wyProgressTimer* disable;
	wyCallFunc* action;
	int type;

public:
	Button2(MyScene* scene, const char* ne, const char* ndis, int type) {
		this->scene = scene;
		this->type = type;

		wyZwoptexManager* zm = wyZwoptexManager::getInstance();

		// create sprites
		enable = zm->makeSprite(ne);
		disable = wyProgressTimer::make(zm->makeSprite(ndis));
		disable->setStyle(RADIAL_CCW); //设置进度条的改变方式
		disable->setScale(0.9f);

		// create atlas button
		button = new wyButton(enable, enable, enable, NULL, NULL,
				wyTargetSelector::make(this, SEL(Button2::onButtonClicked)));
		addChildLocked(button);
		disable->setPosition(button->getPositionX(), button->getPositionY());
		disable->setVisible(false);

		addChildLocked(disable);
	}

	virtual ~Button2() {
	}


	void onButtonClick() {
		switch(type) {
		case Boy::BOY_JUMP:
			scene->jump();
			break;
		case Boy::BOY_HIT:
			scene->shot();
			break;
		}
	}

	void onButtonClickedEnd() {
		disable->setVisible(false);
		button->setEnabled(true);
	}

	void onButtonClicked(wyTargetSelector* ts) {
		button->setEnabled(false);
		disable->setVisible(true);

		wyCallFunc* onaction = wyCallFunc::make(wyTargetSelector::make(this, SEL(Button2::onButtonClick)));
		wyCallFunc* setenable = wyCallFunc::make(wyTargetSelector::make(this, SEL(Button2::onButtonClickedEnd)));
		wySequence* s = wySequence::make(onaction, wyProgressTo::make(3, 100, 0), setenable,  NULL);
		disable->runAction(s);
	}
};


    
[3] 查看装置跑的是当前的哪个activity
    来源: 互联网  发布时间: 2014-02-18
查看设备跑的是当前的哪个activity


找到sdk的安装路径,比如我的是

D:\Program Files\android-sdk-windows\tools\该路径下的如下工具:

hierarchyviewer.bat

双击,可以用此工具查看设备跑的是当前的哪个activity,非常方便哦。


    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android消息处理机制Looper和Handler详解
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3