【Android】用Cubism 2制作自己的Live2D——来制作动态壁纸吧!
前言-
Andorid SDK下载 baidu云 提取码:19jm
这次我们就来研究一下官方的例子之一的liveWallPaper,也就是开发Android的动态壁纸
先来看看这个例子运行的结果:
还是蛮可爱的嘛,那么开始吧!
项目的目录-
framework中是live2d要用的必须的类
libs下是开发必须要用的jar包
-GLWallpaperService.jar
-live2d_android.jar
sample下就是重点了live2DRenderer是绘制模型的类、LiveWallpaperService继承自GLWallPaperService
-这个GLWallPaperService类是动态壁纸的基础类,此类为壁纸项目的开发提供了服务接口,通过集成GLWallPaperService类,重写onCreateEngine()等方法实现壁纸功能。
OK!和昨天工作量差不多嘛!开搞!
模型绘制类live2DRenderer-
对于Renderer上一篇文章已经有了简单的了解->点这里跳转
class SampleGLRenderer implements Renderer{ @Override
//执行渲染工作
public void onDrawFrame(GL10 gl){} @Override
// 渲染窗口大小发生改变或者屏幕方法发生变化时候回调
public void onSurfaceChanged(GL10 gl, int width, int height){} @Override
//surface被创建后需要做的处理
public void onSurfaceCreated(GL10 gl, EGLConfig config){}
}
但是上一个例子中绘制的模型只有头部会左右偏转,并没有实质性的载入动作、物理效果(Motion和Physics)等。
那就看看这些物件是怎么绘制到手机里的吧!
onDrawFrame(GL10 gl)
public void onDrawFrame(GL10 gl) {
// Your rendering code goes here
//对于OpenGL的设置
gl.glMatrixMode(GL10.GL_MODELVIEW ) ;
gl.glLoadIdentity() ;
gl.glClear( GL10.GL_COLOR_BUFFER_BIT ) ;
gl.glEnable( GL10.GL_BLEND ) ;
gl.glBlendFunc( GL10.GL_ONE , GL10.GL_ONE_MINUS_SRC_ALPHA ) ;
gl.glDisable( GL10.GL_DEPTH_TEST ) ;
gl.glDisable( GL10.GL_CULL_FACE ) ; live2DModel.loadParam(); /*motionMgr是MotionQueueManager.class的,从名字就能看出来的个用于存放Motion(.mtn)文件的队列*/
if(motionMgr.isFinished())
{
/*播放动画需要使用MotionQueueManager的startMotion函数
* 第二个参数可以设定动作结束以后删除与否(设置为true时,Live2D会自动调用delete()函数)
*/
motionMgr.startMotion(motion, false);
}
else
{
/*当然只是Motion肯定不能动的,所以必须调用updateParam()函数设定将正在播放的动作参数设定到模型中*/
motionMgr.updateParam(live2DModel);
}
//暂时保存目前所有数值
live2DModel.saveParam();
/*dragMgr是L2DTargetPoint类的,这个L2DTargetPoint用于管理拖拽的坐标,
关于触碰的获取、设备坐标的变换方法,也是壁纸中点击屏幕的任意一点模型就会看向哪里的实现*/
dragMgr.update(); float dragX=dragMgr.getX();
float dragY=dragMgr.getY(); //调整脸的方向
live2DModel.addToParamFloat(L2DStandardID.PARAM_ANGLE_X, dragX*30);
live2DModel.addToParamFloat(L2DStandardID.PARAM_ANGLE_Y, dragY*30); //调整身体的方向
live2DModel.addToParamFloat(L2DStandardID.PARAM_BODY_ANGLE_X, dragX*10); //调整眼球方向,本例中不需要
/*live2DModel.addToParamFloat( "PARAM_EYE_BALL_X", dragX , 1 );
live2DModel.addToParamFloat( "PARAM_EYE_BALL_Y", dragY , 1 );*/ /*这个类是 Live2D 库中简易使用物理演算的封装类。
不使用也可设置物理演算。
L2DPhysics 类的 load 函数用来读取 JSON 文件。
更新时,调用 update 函数,把参数应用在模型上。*/
physics.updateParam(live2DModel); //配置绘图环境
live2DModel.setGL( gl ) ;
//更新顶点
live2DModel.update() ;
//绘制
live2DModel.draw() ;
}
模型绘制
对于OpenGL这一些配置可以参考上一篇的oDrawFrame()函数
onSurfaceCreated(GL10 gl, EGLConfig config)-
public void onSurfaceCreated(GL10 gl, EGLConfig config)
{
AssetManager mngr = con.getAssets();
try
{
InputStream in = mngr.open( MODEL_PATH ) ;
live2DModel = Live2DModelAndroid.loadModel( in ) ;
in.close() ;
}
catch (IOException e)
{
e.printStackTrace();
} try
{
//texture
for (int i = 0 ; i < TEXTURE_PATHS.length ; i++ )
{
InputStream in = mngr.open( TEXTURE_PATHS[i] ) ;
int texNo = UtOpenGL.loadTexture(gl , in , true ) ;
live2DModel.setTexture( i , texNo ) ;
in.close();
}
}
catch (IOException e)
{
e.printStackTrace();
} try
{
InputStream in = mngr.open( MOTION_PATH ) ;
motion = Live2DMotion.loadMotion( in ) ;
in.close() ; in=mngr.open(PHYSICS_PATH);
physics=L2DPhysics.load(in);
in.close();
}
catch (Exception e)
{
e.printStackTrace();
}
}
这个就是用流加载Assets文件夹里的文件到需要他的地方了,与上一篇差别不大,多了Motion和Physics的载入,方法也是一样的。
onSurfaceChanged(GL10 gl, int width, int height)-
public void onSurfaceChanged(GL10 gl, int width, int height) { gl.glViewport( 0 , 0 , width , height ) ; gl.glMatrixMode( GL10.GL_PROJECTION ) ;
gl.glLoadIdentity() ; float modelWidth = live2DModel.getCanvasWidth(); gl.glOrthof(
0 ,
modelWidth ,
modelWidth * height / width,
0 ,
0.5f , -0.5f
) ; glWidth=width;
glHeight=height;
}
也是没什么变化,不过这次我在中文说明书中找到了对这些绘制参数的描述
LiveWallpaperService类-
/*这个GLWallPaperService类是动态壁纸的基础类,此类为壁纸项目的开发提供了服务接口,通过集成GLWallPaperService类,重写onCreateEngine()等方法实现壁纸功能*/
public class LiveWallpaperService extends GLWallpaperService {
public Engine onCreateEngine() {}
class MyEngine extends GLEngine {
public MyEngine() {}
//获取触摸事件
public void onTouchEvent(MotionEvent event) {}
}
}
壁纸类的结构就是这样的,下面是完整代码。
public class LiveWallpaperService extends GLWallpaperService {
public LiveWallpaperService() {
super();
} public Engine onCreateEngine() {
MyEngine engine = new MyEngine();
return engine;
} class MyEngine extends GLEngine {
Live2DRenderer renderer; public MyEngine() {
super();
// handle prefs, other initialization
renderer = new Live2DRenderer(getApplicationContext());
setRenderer(renderer);
setRenderMode(RENDERMODE_CONTINUOUSLY);
} @Override
public void onTouchEvent(MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
break;
case MotionEvent.ACTION_UP:
renderer.resetDrag();
break;
case MotionEvent.ACTION_MOVE:
renderer.drag(event.getX(), event.getY());
break;
case MotionEvent.ACTION_CANCEL:
break;
}
} public void onDestroy() {
super.onDestroy();
if (renderer != null) {
renderer.release();
}
renderer = null;
}
}
}
下面就是我自己尝试的结果了:
-
【Android】用Cubism 2制作自己的Live2D——来制作动态壁纸吧!的更多相关文章
- 【Android】用Cubism 2制作自己的Live2D——初见!
前言- 现在很多手游的UI上都不约而同的放置一个Live2D模型,这仿佛已经成为了一个业界的潜规则之类的东西.作为一名深受手机游戏毒害的90后,我也没有忘记小时候励志当一名技术宅的梦想,也想试试自己做 ...
- 【Android】用Cubism 2制作自己的Live2D——android sdk样本的下载与Android studio编译!
前言- 在浏览Live2d说明书的时候我无意中发现了一个有趣的东西,就是android sdk中居然自带动态壁纸!那就让我们来试试吧,说明书此页的网址连接——中文版||日文版 Android开发所必需 ...
- INNO 补丁制作技术, 打开 INNO 补丁制作方法的第一页
INNO 补丁制作技术, 打开 INNO 补丁制作方法的第一页 作者:xin 日期:2005-09-23 字体大小: 小 中 大 VPatch 在 INNO 中的应用. VPatch 属于专为NS ...
- android浪漫樱花凋零动态壁纸应用源码
android浪漫樱花凋零动态壁纸应用源码,是从那个安卓教程网拿过来的,本项目是一套基于安卓的樱花动态壁纸项目源码,安装以后桌面没有图标,但是可以在修改壁纸-动态壁纸中找到.我的分辨率是480×854 ...
- Ruby Rose动态壁纸制作记录
为Wallpaper Engine做的动态壁纸,使用Unity制作,在这里记录一下制作过程和一些遇到的坑,以后有了github账号再搬到那边去. 最后大概要做出这样的效果,截图来自RWBY " ...
- 关于VS2013下制作和使用静态库和动态库
关于VS2013下制作和使用静态库和动态库 引言 什么是库:库是写好的现有的,成熟的,可以复用的代码. 所谓静态.动态是指链接.将一个程序编译成可执行程序的步骤: 静态库在链接阶段,会将汇编生成的目标 ...
- Web app制作细节:web app互动制作技巧
Google .微软.苹果三大巨头紧锣密鼓地在web app的研发产品领域圈地设岗,并试图建立以自己为中心的”云“服务平台,企图在web app时代到来的时候充当霸主.本文将围绕web app的制作, ...
- PageAdmin CMS网站制作教程实例:如何制作一个报名表?
PageAdmin CMS网站建设实例:如何制作一个报名表? 有时我们根据需求需要制作一些自定义表,该如何去制作呢? 我们以制作一个报名表为例: 登录后台地址,进入后台, 2.在顶部导航中找到系统,并 ...
- Android零基础入门第44节:ListView数据动态更新
原文:Android零基础入门第44节:ListView数据动态更新 经过前面几期的学习,关于ListView的一些基本用法大概学的差不多了,但是你可能发现了,所有ListView里面要填充的数据都是 ...
随机推荐
- 【转】sentry 实时事件日志聚合平台
1.install postgreSQL(v9.6)2.pip install sentry(v8.13.0)3.sentry init #初始化配置文件 4.配置好postgreSQL 需要连接re ...
- springboot+redis实现分布式session共享
官方文档,它是spring session项目的redis相关的一个子文档:https://docs.spring.io/spring-session/docs/2.0.0.BUILD-SNAPSHO ...
- CF泛做
CF Rd478 Div2 A Aramic script 题意:给定几个字符串,去重后,求种类 思路:直接map乱搞 #include<bits/stdc++.h> using name ...
- 分布式系统之CAP理论杂记
分布式系统的CAP理论:理论首先把分布式系统中的三个特性进行了如下归纳:● 一致性(C):在分布式系统中的所有数据备份,在同一时刻是否同样的值.● 可用性(A):在集群中一部分节点故障后,集群整体是否 ...
- Spring Boot整合Quartz实现定时任务表配置
最近有个小项目要做,spring mvc下的task设置一直不太灵活,因此在Spring Boot上想做到灵活的管理定时任务.需求就是,当项目启动的时候,如果有定时任务则加载进来,生成schedule ...
- Java Persistence/ManyToMany
A ManyToMany relationship in Java is where the source object has an attribute that stores a collecti ...
- 常用JS对象的方法总结
String 方法 描述 charAt() 返回在指定位置的字符. charCodeAt() 返回在指定的位置的字符的 Unicode 编码. concat() 连接字符串. indexOf() 检索 ...
- error LNK2001: 无法解析的外部符号 解决方法
错误提示:LNK2001 无法解析的外部符号 "public: class el::base::Writer & __cdecl el::base::Writer::construc ...
- (二)Maven的安装与环境配置
主要内容 在Windows上安装Maven 安装目录分析 在Windows上安装Maven 本机环境:Windows10,JDK9.0.4. 想要安装Maven,需要下载Maven的zip文件,并将其 ...
- Mave手动安装jar包
今天配置Maven项目时有一个相应的jdbc驱动jar包导不进去,就自己导入了. 首先在官网上下载该jar包,地址为http://mvnrepository.com/ 点击jar下载. 用maven命 ...