介绍一下使用Titanium的Module功能来制作自定义的View。
这里只是想整理一下最低限度的步骤和方法,所以自定义的内容只是简单地给普通的View类添加颜色。
Porject做成
根据
Titanium中Android模块开发指南(中文) 的内容,大家应该能很容易的创建一个Module的模板工程。
引用
titanium create --platform=android --type=module --name=ColoredView --id=net.siso9to.coloredview --android=$HOME/devel/android-sdk-mac_x86
将做成好的模板工程导入到Eclipse中,Module的准备工作就算完成了。
Module做成
导入的模板工程的包目录下,有两个类文件:
ColoredviewModule.java
ExampleProxy.java
这样原封不动的也是没有问题的,但是我们看到类名中view的第一字母小写了,不是很符合规范,所以我们使用重构功能将类名修改为:ColoredViewModule.java。使用Eclipse的重构功能的话,注解位置部分
@Kroll.module(name="Coloredview", id="net.siso9to.coloredview")
的name参数没有给重命名,所以这里需要手动修改。
还有就是类中不用的方法,注释等都删去,ExampleProxy.java也要重写做一个,所以也一并删去。
修改之后的ColoredViewModule.java的内容是一下这个样子的:
package net.siso9to.coloredview;
import org.appcelerator.kroll.KrollModule;
import org.appcelerator.kroll.annotations.Kroll;
import org.appcelerator.titanium.TiContext;
@Kroll.module(name="ColoredView", id="net.siso9to.coloredview")
public class ColoredViewModule extends KrollModule
{
public ColoredViewModule(TiContext tiContext) {
super(tiContext);
}
}
这样就留下来了最低限度代码的Module。
自定义View做成
要做成自定义View,需要创建一个继承了TiUIView的类。
然后,自定义View的时候,还需要再TiUIView的子类中生成View实例,调用setNativeView()方法将该子类保存。
package net.siso9to.coloredview;
import org.appcelerator.titanium.proxy.TiViewProxy;
import org.appcelerator.titanium.view.TiUIView;
import android.content.Context;
import android.graphics.Color;
import android.view.View;
public class ColoredView extends TiUIView {
public class CostomView extends View {
public CostomView(Context c) {
super(c);
this.setBackgroundColor(Color.GREEN);
}
}
public ColoredView(TiViewProxy proxy) {
super(proxy);
CostomView costomView = new CostomView(proxy.getContext());
setNativeView(costomView);
}
}
Proxy做成
最后,要做成一个能偶再Module中调用刚才做成的自定义View的Proxy类。
调用刚才做成的自定义View的Proxy类在做成的时候,需要继承TiViewProxy,然后,实现createView(Activity activity)方法,将自定义View的实例类返回。
package net.siso9to.coloredview;
import org.appcelerator.kroll.annotations.Kroll;
import org.appcelerator.titanium.TiContext;
import org.appcelerator.titanium.proxy.TiViewProxy;
import org.appcelerator.titanium.view.TiUIView;
import android.app.Activity;
@Kroll.proxy(creatableInModule=ColoredViewModule.class)
public class ColoredViewProxy extends TiViewProxy
{
private ColoredView coloredView;
public ColoredViewProxy(TiContext tiContext) {
super(tiContext);
}
@Override
public TiUIView createView(Activity activity) {
coloredView = new ColoredView(this);
return coloredView;
}
}
在构造函数中,通过setBackgroundColor(Color.GREEN)的设置,View的背景色就被设置上了。
需要注意的地方是,再做成Proxy类的时候,需要像以下这个样子将注解的creatableInModule值设置成和Module名一样。
@Kroll.proxy(creatableInModule=ColoredViewModule.class)
确认动作的Script做成
做好了Module之后,我们需要确认以下该Module是否能正常的运行,是否能达到我们需要的效果。
在确认Module的效果前,我们需要将Module集成到我们的Titanium当中来,使用example文件夹下的app.js就能确认Module的效果。
稍微修改一下通过Titanium命令生成的example/app.js:
var window = Ti.UI.createWindow({
backgroundColor:'white'
});
var label = Ti.UI.createLabel();
window.add(label);
window.open();
var module = require('net.siso9to.coloredview');
Ti.API.info("module is => " + module);
var view = module.createColoredView({
top: '100dp',
width : '100dp',
height : '100dp',
color: '#000',
});
window.add(view);
从Module经由Proxy调用自定义View时,并不是直接的调用Proxy的createView方法,而是向上面代码这样:
create + Proxy名(去除Proxy)
确认动作的Script的运行
修改完app.js之后,通过ant我们来运行这个script。
在build.xml文件上点击右键,选择「Debug As」 > 「2 Ant Build...」
在表示出来的Ant的Task一览中,我们选择「clean」和「run」。
※如果只是选择ruan的话,可能会残留一些不必要的文件,从而引起编译失败,所以这里也先选上clean
然后按下「Debug」之后运行,成功启动模拟器之后,就能看到一下的页面了,绿色部分就是这回自定义的View。
这里只是说明了如果自定义一个View,其中最大限度的省略了一些其他的代码,如果大家要自定义View的话,应该不会这个简单,但是过程基本上是这样的。
- 大小: 26.9 KB
- 大小: 66.6 KB
- 大小: 10.8 KB
- 大小: 17.9 KB
分享到:
相关推荐
titanium-appcelerator-progress-view, 在 Titanium Appcelerator项目中,要使用的自定义进度视图 进度视图这是一个进度视图,显示你的应用程序的某些状态。 你可以设置加载,成功和错误状态。只使用三行代码,你就...
5. **依赖库**:`node-titanium-sdk`可能依赖于其他Node.js模块,这些模块可能被包含在压缩包中,或者需要通过npm(Node.js的包管理器)进行安装。 6. **配置文件**:项目所需的配置文件,如`.tss`(样式表文件)和...
titanium-appcelerator-pull-to-refresh, 在your中,创建"pull to refresh" 视图的JavaScript方法 什么?这种方法,将帮助你在你的篓中制作视图"拖到刷新"。?要使用这里方法,你需要将这些文件包含在项目中:Ti....
钛备份Titanium Backup Pro是目前为最强悍的程序和系统备份工具,需ROOT权限运行。它的程序命名就是一个暗示,钛(元素名Ti),是一种高档的金属,特点是重量轻但是强度大,相当稳固,被广泛应用于航天和航海这些...
Android-titanium_mobile.zip,带有javascript的本地ios、android和windows应用程序,安卓系统是谷歌在2008年设计和制造的。操作系统主要写在爪哇,C和C 的核心组件。它是在linux内核之上构建的,具有安全性优势。
Google-Cloud-Messaging--Titanium- Android 平台正在使用 c2dm 进行推送通知,但由于 c2dm 已停止接受新用户,因此我们决定使用 google 提供的新服务,即 Google Cloud Messaging (GCM)。 当前最新版本是 0.5更改...
适用于 Android 的 Parse.com Titanium 模块关于模块该模块的存在是为了向 Appcelerator 开发人员提供一个开源(在 MIT 许可下获得许可)Android 模块来包装 Android Parse SDK 的功能。 它试图保持与 iOS Titanium ...
本书由Boydlee Pollentine撰写,包含了超过80个实际的开发示例,旨在帮助读者快速掌握TITANIUM的使用技巧,并能够创建针对iPhone和Android平台的原生移动应用。 - **目标读者**:本书适合有一定JavaScript基础并对...
Google-Cloud-Messaging--Titanium-, 在 Titanium 中,Google云消息传递 Google-Cloud-Messaging--Titanium -注册带有GCM和处理发送到设备的通知的Titanium MODULE 。Android平台使用c2dm进行推送,但是因为c2dm停止...
Titanium 的核心理念是通过跨平台的 JavaScript API 提供与原生功能的无缝对接,而插件开发则是这一理念的延伸,使开发者能够自定义特定的功能或服务。 **1. 插件的概念与作用** Titanium 插件是扩展其核心功能的一...
atom-titanium, 用于 Titanium 合金的Atom 封装 用于 Titanium 合金的 All-in-One封装这是一个用于 Titanium 合金的Atom 封装。$ apm install titanium-alloy冲突&需要通知Alloy 1.8. x
命令描述键绑定Titanium: Create application 创建一个新的Titanium应用程序项目-- Titanium: Create module 创建一个新的Titanium模块项目-- Titanium: Enable LiveView 启用LiveView -- Titanium: Disable ...
**Titanium中文版开发手册** Titanium中文版开发手册是一份专门为中文用户编译的开发者指南,旨在帮助熟悉中文的开发者充分利用Titanium框架进行移动应用的开发。Titanium是一个开源的JavaScript平台,允许开发者...
用于 MapView 自定义注释的 Titanium android 模块。 通过资源 xml 文件完全可定制的注释。 还没有完成 ****去做 1.Clustering 2.Annotation Selector 3.Using image from JavaScript in annotation 联系我进行...
要获得编程帮助,请使用带有标签Titanium-Web-Proxy的 。 产品特点 采用服务器连接池,证书缓存和缓冲池的多线程全异步代理 查看/修改/重定向/阻止请求和响应 支持相互SSL身份验证,代理身份验证和自动上游代理检测...
此外,Titanium还支持自定义模块,允许开发者用原生代码编写特定功能,然后在JavaScript中调用。 ### 应用生命周期管理 Titanium处理了应用的生命周期事件,如启动、暂停、恢复和关闭。开发者可以通过监听这些事件...
Titanium Mobile SDK 3.1.0 是一个用于构建原生移动应用的开发工具,尤其针对iOS和Android平台。这个版本的Apidoc是开发者的重要参考资料,它包含了完整的API文档,帮助开发者理解并使用Titanium框架的各种功能。...
确保titanium-firebase模块已全局安装或安装在<project>/modules目录中内容配置您的tiapp.xml和所需的元文件( GoogleService-Info.plist + google-services.json ) Analytics SDK的用法示例作者汉斯·( / )执照...
Titanium作为一款强大的跨平台开发框架,使得开发者能够用JavaScript编写原生iOS应用,而Titanium-WatchOS2-Sample-App则为开发者提供了一个直观的示例,展示了如何在watchOS 2应用程序与Titanium应用程序之间进行...