当前位置:  编程技术>移动开发
本页文章导读:
    ▪AchartEngine 绘图相干收集        AchartEngine 绘图相关收集 achartengine官网http://code.google.com/p/achartengine/ 1.使用AChartEngine画柱状图http://blog.csdn.net/kmyhy/article/details/63236932.使用achartengine开发曲线图相关的Android应用程序http://blog.s.........
    ▪ String , StringBuffer, StringBuilder的差别        String , StringBuffer, StringBuilder的区别 String 是不可改变,定长;StringBuffer, StringBuilder 是不定长,可改变.注意:本来以为StringBuilder 和StringBuffer 的equals 方法是可以比较两个字符串的内容是否相等.........
    ▪ ibooks 3d 翻转成效 flip 3d       ibooks 3d 翻转效果 flip 3d Bells And Whistles The iPhone has a set of nice transition animations which makes the experience using it very pleasant. But after a while one get so used of them that one stop noticing that they are even there. But.........

[1]AchartEngine 绘图相干收集
    来源: 互联网  发布时间: 2014-02-18
AchartEngine 绘图相关收集
achartengine官网
http://code.google.com/p/achartengine/


1.使用AChartEngine画柱状图
http://blog.csdn.net/kmyhy/article/details/6323693

2.使用achartengine开发曲线图相关的Android应用程序
http://blog.sina.com.cn/s/blog_776989950100vxej.html

3.折线图:
http://blog.csdn.net/kmyhy/article/details/6584298



http://immortal.5d6d.com/thread-710-1-1.html

    
[2] String , StringBuffer, StringBuilder的差别
    来源: 互联网  发布时间: 2014-02-18
String , StringBuffer, StringBuilder的区别

String 是不可改变,定长;
StringBuffer, StringBuilder 是不定长,可改变.
注意:本来以为StringBuilder 和StringBuffer 的equals 方法是可以比较两个字符串的内容是否相等,今天才发现不是这么回事。这两个类都直接继承自Object ,并且没有重写equals 方法。

Java代码 
StringBuilder sb1 = new StringBuilder("123");   
StringBuilder sb2 = new StringBuilder("123"); System.out.println(sb1.equals(sb2));  
输出结果是:false 

StringBuilder sb1 = new StringBuilder("123");
StringBuilder sb2 = new StringBuilder("123"); System.out.println(sb1.equals(sb2));
输出结果是:false
 
  若要比较内容是否相同,sb1.toString().equals(sb2.toString())

 

  简要的说, String 类型和 StringBuffer 类型的主要性能区别其实在于 String 是不可变的对象, 因此在每次对 String 类型进行改变的时候其实都等同于生成了一个新的 String 对象,然后将指

针指向新的 String 对象,所以经常改变内容的字符串最好不要用 String ,因为每次生成对象都会对系统性能产生影响,特别当内存中无引用对象多了以后, JVM 的 GC 就会开始工作,那速度是一定

会相当慢的。
   而如果是使用 StringBuffer 类则结果就不一样了,每次结果都会对 StringBuffer 对象本身进行操作,而不是生成新的对象,再改变对象引用。所以在一般情况下我们推荐使用 StringBuffer ,特

别是字符串对象经常改变的情况下。而在某些特别情况下, String 对象的字符串拼接其实是被 JVM 解释成了 StringBuffer 对象的拼接,所以这些时候 String 对象的速度并不会比 StringBuffer 对

象慢,而特别是以下的字符串对象生成中, String 效率是远要比 StringBuffer 快的:

Java代码 
String S1 = “This is only a” + “ simple” + “ test”;   
StringBuffer Sb = new StringBuilder(“This is only a”).append(“ simple”).append(“ test”);   

String S1 = “This is only a” + “ simple” + “ test”;
StringBuffer Sb = new StringBuilder(“This is only a”).append(“ simple”).append(“ test”);   
   你会很惊讶的发现,生成 String S1 对象的速度简直太快了,而这个时候 StringBuffer 居然速度上根本一点都不占优势。其实这是 JVM 的一个把戏,在 JVM 眼里,这个


 String S1 = “This is only a” + “ simple” + “test”; 其实就是:
 String S1 = “This is only a simple test”; 所以当然不需要太多的时间了。但大家这里要注意的是,如果你的字符串是来自另外的 String 对象的话,速度就没那么快了,譬如:

 


Java代码 
String S2 = “This is only a”;   
String S3 = “ simple”;   
String S4 = “ test”;   
String S1 = S2 +S3 + S4;   

String S2 = “This is only a”;
String S3 = “ simple”;
String S4 = “ test”;
String S1 = S2 +S3 + S4;   
这时候 JVM 会规规矩矩的按照原来的方式去做


在大部分情况下 StringBuffer > String
StringBuffer
Java.lang.StringBuffer 线程安全的可变字符序列。一个类似于 String 的字符串缓冲区,但不能修改。虽然在任意时间点上它都包含某种特定的字符序列,但通过某些方法调用可以改变该序列的长度

和内容。可将字符串缓冲区安全地用于多个线程。可以在必要时对这些方法进行同步,因此任意特定实例上的所有操作就好像是以串行顺序发生的,该顺序与所涉及的每个线程进行的方法调用顺序一 致


StringBuffer 上的主要操作是 append 和 insert 方法,可重载这些方法,以接受任意类型的数据。每个方法都能有效地将给定的数据转换成字符串,然后将该字符串的字符追加或插入到字符串缓冲区

中。 append 方法始终将这些字符添加到缓冲区的末端;而 insert 方法则在指定的点添加字符。
    例如,如果 z 引用一个当前内容是“start” 的字符串缓冲区对象,则此方法调用 z.append("le") 会使字符串缓冲区包含“startle” ,而 z.insert(4, "le") 将更改字符串缓冲区,使之包含

“starlet” 。
在大部分情况下 StringBuilder > StringBuffer

java.lang.StringBuilde
java.lang.StringBuilder 一个可变的字符序列是5.0 新增的。此 类提供一个与 StringBuffer 兼容的 API ,但不保证同步。该类被设计用作 StringBuffer 的一个简易替换,用在字符串缓冲区被单

个线程使用的时候(这种情况很普遍)。如果可能,建议优先采用该类,因为在大多数实现中,它比 StringBuffer 要快。两者的方法基本相同。

通过非官方试验测试,StringBuilder 和StringBuffer 的测试总结如下:

1 .  为了获得更好的性能,在构造 StirngBuffer 或 StirngBuilder 时应尽可能指定它的容量。当然,如果你操作的字符串长度不超过 16 个字符就不用了。

2 .  相同情况下使用 StirngBuilder 相比使用 StringBuffer 仅能获得 10%~15% 左右的性能提升,但却要冒多线程不安全的风险。而在现实的模块化编程中,负责某一模块的程序员不一定能清晰地

判断该模块是否会放入多线程的环境中运行,因此:除非你能确定你的系统的瓶颈是在 StringBuffer 上,并且确定你的模块不会运行在多线程模式下,否则还是用 StringBuffer 吧

3 .  用好现有的类比引入新的类更重要。很多程序员在使用 StringBuffer 时是不指定其容量的(至少我见到的情况是这样),如果这样的习惯带入 StringBuilder 的使用中,你将只能获得 10 %左

右的性能提升(不要忘了,你可要冒多线程的风险噢);但如果你使用指定容量的 StringBuffer ,你将马上获得 45% 左右的性能提升,甚至比不使用指定容量的 StirngBuilder 都快 30% 左右。


    
[3] ibooks 3d 翻转成效 flip 3d
    来源: 互联网  发布时间: 2014-02-18
ibooks 3d 翻转效果 flip 3d

Bells And Whistles

The iPhone has a set of nice transition animations which makes the experience using it very pleasant. But after a while one get so used of them that one stop noticing that they are even there. But this is not necessary a bad thing. Often I think that really good things doesn’t show at all, they don’t get in the way. In 3D application really good things make the experience so natural that one afterwards can wonder what the big deal was, really impressive 3D isn’t at all impressive. But, this is not about not noticing. After a while one maybe want to make that little extra in an iPhone app ie making a view transition more natural for the app. Some ebook readers have made page turning transitions.

I have for some time had the notion how to implement it, but as always, But frankly, nothing is really solved until it is shown to work.  So, this weekend I set out to make a reusable class for a OpenGL ES based view transition animation.

My idea was basically as following

  • Make a screen shot of the current view
  • Create a texture of the screen shot
  • Create a view with an OpenGL ES context, make it opaque=NO
  • Make it reusable with a delegate protocol for animation parts

Said and done. So how did this work? I’d say it worked pretty good. Maybe there is better ways to go from screen shot to texture but the well used screen grabbing code is solid.

UIGraphicsBeginImageContext(view.bounds.size);
[view.layer renderInContext:UIGraphicsGetCurrentContext()];
UIImage *image = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();

A utility should be valued by how easy it is used. Too often I see OOP programmers making no effort at simplify a framework. Read about pseudo-classes . So how much has to be done to use this transition view? It boils down to two parts, the actual animation and the integration into Cocoa touch views. The actual animation calls are what they are, but I separated it into two delegate methods, setupTransition and drawTransitionFrame. Then creating the objects and make use of them can look like this (from the demo project using the Utility Application Xcode template).

- (IBAction)showInfo {     
    FlipsideViewController *controller = [[FlipsideViewController alloc] 
                                          initWithNibName:@"FlipsideView" 
                                          bundle:nil];
    controller.delegate = self;

    // Create animation delegate
    DemoTransition *transition = [[[DemoTransition alloc] init] autorelease];

    // Create animation view and feed the delegate
    EPGLTransitionView *glview = [[[EPGLTransitionView alloc] 
                                   initWithView:self.view
                                   delegate:transition] autorelease];
    [glview startTransition];

    // Animation will be run on top off next view 
    [self presentModalViewController:controller animated:NO];
    [controller release];
}

Update: Added features to include transition into next view, grabbing next view as a texture and making it available for the drawTransitionFrame method

Grab the source code and a Xcode demo project at github 

 

 

 

 

 

 

直接上代码最直接。


    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
oracle iis7站长之家
▪根据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