当前位置:  编程技术>移动开发
本页文章导读:
    ▪OpenGL鼠标捡取        OpenGL鼠标拾取 1.OpenGL自带拾取功能。glSelectBuffer等函数完成。   大每一本OpenGL入门的书都会讲到OpenGL的Select模式,它采用一种方法使得可以获取当前鼠标点选的几何图形。简单的来说这种方.........
    ▪ TableCell 右边的小箭头        TableCell 右方的小箭头 最近用到了tableCell ,但右方始终会有一个小箭头,这并不是我想要的的,用下面的方法可以去掉:   _cell.accessoryType=UITableViewCellAccessoryNone; 这里要标记一下,希望遇到.........
    ▪ 关于Class对象的功用与产生       关于Class对象的作用与产生   Class对象是用来创建类的常规对象的,当我们编译一个Java类就会同时产生一个与该类相对应的Class对象(保存在.class文件中)。   Class对象是用来创建类的.........

[1]OpenGL鼠标捡取
    来源: 互联网  发布时间: 2014-02-18
OpenGL鼠标拾取

1.OpenGL自带拾取功能。glSelectBuffer等函数完成。

  大每一本OpenGL入门的书都会讲到OpenGL的Select模式,它采用一种方法使得可以获取当前鼠标点选的几何图形。简单的来说这种方式就是首先调 整Projection矩阵,使得你透过从鼠标点选附近的一个正方形(大小可设置)看到的世界。然后开始绘制,当每一次绘制的时候都会判断你会不会看到。 如果看到,那么,你就是选择了这个几何图形了。更为具体的过程可以参见相关的书籍。

http://hi.baidu.com/sishenfuhuo/blog/item/e98b852ef94013371e30892a.html2.在OpenGL红宝书中介绍了一种简便易行的办法:在后缓冲中 使用不同的颜色重绘所有对象,每个对象用一个单色来标示其颜色,这样画好之后我们读取鼠标所在点的颜色,就能够确定我们拣选了哪个物体。这种方法有一个缺 陷,当场景中需要选择的对象的数目超出一定限度时,可能会出现标识数的溢出。对于这个问题,红宝书给出的解决办法就是多次扫描。实践证明这种方法的确简便 易行,但仍有不少局限性,而且做起来并不比第一种机制方便多少。限于篇幅,不再赘述。

 

3.还有一种方法是射线相交检测法。

http://www.ophonesdn.com/article/show/164

 

4.关于相交性检测的文章如下

http://www.cnblogs.com/graphics/archive/2010/08/09/1795348.html

 

1.先用参数法求交点 ,然后 用叉乘公式可以求得面积,用面积法判断是否在之内。

2.或者用上面的参数法。直接定义一个三角形内的点。然后用u,v参数表示。求得参数后,根据范围来判断。

 

 

段页式内存管理, 逻辑地址, 线性地址, 物理地址 等等
逻辑地址(Logical Address) 是 指由程序产生的与段相关的偏移地址部分。例如,你在进行C语言指针编程中,可以读取指针变量本身值(&操作),实际上这个值就是逻辑地址,它是相 对于你当前进程数据段的地址,不和绝对物理地址相干。只有在Intel实模式下,逻辑地址才和物理地址相等(因为实模式没有分段或分页机制,Cpu不进行 自动地址转换);逻辑也就是在Intel 保护模式下程序执行代码段限长内的偏移地址(假定代码段、数据段如果完全一样)。应用程序员仅需与逻辑地址打交道,而分段和分页机制对您来说是完全透明 的,仅由系统编程人员涉及。应用程序员虽然自己可以直接操作内存,那也只能在操作系统给你分配的内存段操作。

线性地址(Linear Address) 是逻辑地址到物理地址变换之间的中间层。程序代码会产生逻辑地址,或者说是段中的偏移地址,加上相应段的基地址就生成了一个线性地址。如果启用了分页机 制,那么线性地址可以再经变换以产生一个物理地址。若没有启用分页机制,那么线性地址直接就是物理地址。Intel 80386的线性地址空间容量为4G(2的32次方即32根地址总线寻址)。

物理地址(Physical Address) 是指出现在CPU外部地址总线上的寻址物理内存的地址信号,是地址变换的最终结果地址。如果启用了分页机制,那么线性地址会使用页目录和页表中的项变换成物理地址。如果没有启用分页机制,那么线性地址就直接成为物理地址了。

虚拟内存(Virtual Memory) 是指计算机呈现出要比实际拥有的内存大得多的内存量。因此它允许程序员编制并运行比实际系统拥有的内存大得多的程序。这使得许多大型项目也能够在具有有限 内存资源的系统上实现。一个很恰当的比喻是:你不需要很长的轨道就可以让一列火车从上海开到北京。你只需要足够长的铁轨(比如说3公里)就可以完成这个任 务。采取的方法是把后面的铁轨立刻铺到火车的前面,只要你的操作足够快并能满足要求,列车就能象在一条完整的轨道上运行。这也就是虚拟内存管理需要完成的 任务。在Linux 0.11内核中,给每个程序(进程)都划分了总容量为64MB的虚拟内存空间。因此程序的逻辑地址范围是0x0000000到0x4000000。

有时我们也把逻辑地址称为虚拟地址。因为与虚拟内存空间的概念类似,逻辑地址也是与实际物理内存容量无关的。

逻辑地址与物理地址的“差距”是0xC0000000,是由于虚拟地址->线性地址->物理地址映射正好差这个值。这个值是由操作系统指定的。

http://www.mtime.com/my/1085324/blog/1499099/


    
[2] TableCell 右边的小箭头
    来源: 互联网  发布时间: 2014-02-18
TableCell 右方的小箭头

最近用到了tableCell ,但右方始终会有一个小箭头,这并不是我想要的的,用下面的方法可以去掉:

  _cell.accessoryType=UITableViewCellAccessoryNone;

这里要标记一下,希望遇到相同问题的朋友可以用到。


    
[3] 关于Class对象的功用与产生
    来源: 互联网  发布时间: 2014-02-18
关于Class对象的作用与产生

 

Class对象是用来创建类的常规对象的,当我们编译一个Java类就会同时产生一个与该类相对应的Class对象(保存在.class文件中)。

  Class对象是用来创建类的常规对象的,当我们编译一个Java类就会同时产生一个与该类相对应的Class对象(保存在.class文件中)。该Class对象中保存了创建对象所需的所有信息。

  共有三种产生Class对象的方法下面分别说明之:

  1.public static Class Class.forName("完整的类名") throws ClassNotFoundException;

  public static Class forName(String name, boolean initialize,

  ClassLoader loader) throws ClassNotFoundException

  假若我们用Class.forName("");的方式获取Class对象,其实就相当于Class.forName("完整类名", true, this.getClass().getClassLoader())也就是说在默认情况下在产生Class对象的同时会对该Class对象进行初始化(若以前没有初始化过)。

  2.public final Class getClass()

  可以通过任何实例对象来引用该方法来获取相应的Class对象。使用此种方式的前提是我们需要产生相应的实例对象。

  3.类名.class 此种方式产生Class对象较前两种简单,无需第一种还要进行异常处理(在编译期就进行错误的检查了)。此种方式不会自动初始化该Class对象。初始化被延迟到对静态方法(包括构造方法)或非常数静态域进行首次引用时才进行。

 

 

      import java.util.*;

  class Initable{

  static final int staticFinal = 47;

  static final int staticFinal2 = ClassInitialization.rand.nextInt(100);

  static{

  System.out.println("Initialization Initable");

  }

  }

  class Initable2{

  static int staticNoFinal = 147;

  static{

  System.out.println("Initialization Initable2");

  }

  }

  class Initable3{

  static int staticNoFinal = 74;

  static{

  System.out.println("Initialization Initable3");

  }

  }

  public class ClassInitialization

  {

  public static Random rand = new Randdom(47);

  public static void main(String[] args){

  Class initable = Initable.class; //不会引起初始化

  System.out.println("after creating Initable reference");

  System.out.println(Initable.staticFinal); //引用编译器常量不会引起初始化

  System.out.println(Initable.staticFinal2); //引起初始化

  System.out.println(Initable2.staticNoFinal); //引用非编译期常量会引起初始化

  Class initable3 = Class.forName("Initable3"); //默认会引起初始化

  System.out.println("after creating Initable3 reference");

  System.out.println(Initable3.staticNoFinal);//前面已经初始化此处不用再初始化

  }

  }


    
最新技术文章:
▪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