- 浏览: 199969 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
hao3721:
dsfasd
ehcache 使用 -
nihaokid:
方法是不会存在在对象内存中的,它存在于方法区,建议看看jvm的 ...
Java 深层理解 父类引用指向子类对象 -
vissalan:
有一点没看明白Father f1 = (Father)s;这时 ...
Java 深层理解 父类引用指向子类对象 -
咖啡舞者:
非常感谢这种分享精神.
在BREW中实现自己的GUI(8)-IWEB的封装 -
咖啡舞者:
这是创建的代码。
在设备上调的。
界面在手机和模拟器上显示的差异
要实现的菜单比较简单,只支持列表视图,也就是IMenuCtl中的AEECLSID_MENUCTL 模式。
但是我们需要考虑两个要求:
1.菜单需要一个背景图,并且在每一个选中项的背景不仅仅是简单地填充色,而应该是一个图片(这样我们就可以方便地实现渐变、光晕、立体等效果了)。
2.它应该在调用接口方面与原有的IMenuCtl基本一致,这样便于我们移植原来的代码。
首先,在h文件中对菜单各个实体先做个定义如下:
typedef struct
...{
const AECHAR * pText; // Text
IImage * pImage; // Image
const char * pszResImage;
const char * pszResText;
uint16 wText;
uint16 wImage;
uint16 wItemID;
uint32 dwData;
} GMenuItem;
typedef struct
...{
RGBVAL cText;
RGBVAL cSelText;
} GMenuColors;
GMenuItem很好理解,明显是模仿着CtlAddItem来作的,只是省掉了一些东西罢了。
另外,关键的问题在于整个菜单结构的定义,如下:
const AEEVTBL(IGMenuCtl) * pvt;
uint32 m_nRefs;
IShell *m_pIShell;
IDisplay *m_pIDisplay;
IModule *m_pIModule;
IImage *m_pImageBk;
IImage *m_pImageSe;
TQueueList *m_pDataList;
int m_Index;
int m_startIndex;
int m_pageSize;
int m_textPos;
boolean m_isActive;
AEERect m_Rect;
GMenuColors m_Colors;
uint32 m_Properties;
};
前面的AEEVTBL就不说了,因为我们整个扩展GUI都是采用BREW的扩展类机制来实现的,具体方法可以参考相关资料。在这个菜单中,关键点是我们定义了一个背景图m_pImageBk和选中项的背景图m_pImageSe。其它几个字段象index/pagesize等等都是控制菜单行为的。用一个TQueueList来保存菜单项的链表(这个TQueueList也是自已实现的一个链表结构)。
好了,在实现中如何处理呢?先来看看看我们都需要些什么函数?
...{
DECLARE_IBASE(IGMenuCtl)
DECLARE_ICONTROL(IGMenuCtl)
boolean (*AddItem) (IGMenuCtl * po,const char * pszResFile,uint16 wResID,uint16 nItemID,AECHAR * pText,uint32 lData);
boolean (*AddItemEx) (IGMenuCtl * po, GMenuItem * pai);
boolean (*GetItemData) (IGMenuCtl * po, uint16 nItemID, uint32 * plData);
void (*SetSel) (IGMenuCtl * po, uint16 nItemID);
uint16 (*GetSel) (IGMenuCtl * po);
int (*CurrentIndex) (IGMenuCtl * po);
int (*GetItemCount) (IGMenuCtl * po);
uint16 (*GetItemID) (IGMenuCtl * po, int nIdx);
boolean (*GetItem) (IGMenuCtl * po, uint16 wID, GMenuItem * pai);
boolean (*SetItem) (IGMenuCtl * po, uint16 wID, uint16 wFlags,GMenuItem * pai);
void (*SetItemText) (IGMenuCtl * po, uint16 wID,const char * pszResFile,uint16 wResID,AECHAR * pText);
void (*SetImageBk) (IGMenuCtl * po,IImage * pImg);
void (*SetImageSe) (IGMenuCtl * po,IImage * pImg);
void (*SetColors) (IGMenuCtl * pIMenuCtl, GMenuColors * pc);
};
大多数函数都是模仿着IMenuCtl来定义的,只有这样才可以方便地将原来的基于IMenuCtl的代码移植到我们的IGMenuCtl上来。
OK,剩下的事情就好办了。在HandleEvent中,处理几个键,用户按了上下方向键则修改m_Index来改变菜单的当前选中项索引,用户按了SELECT键则发送一个EVT_COMMAND事件即可,如:ISHELL_PostEvent(pMe->m_pIShell,0,EVT_COMMAND,0,0)。
而在Redraw中,就是我们实际的绘制过程了,步骤是先绘背景m_pImageBk,再循环m_pDataList绘制每一个项,如果是选中项则给他绘一个背景m_pImageSe。代码如下:
...{
int i,j,height,h,a,b;
AEEImageInfo infSe,infIc;
AEERect rec;
int xx,yy,dxx,dyy;
RGBVAL oldColor;
GMenuItem * pData=NULL;
TQueueList * p = pMe->m_pDataList;
ZEROAT(&infSe);
IDISPLAY_EraseRect(pMe->m_pIDisplay,&pMe->m_Rect);
h=IDISPLAY_GetFontMetrics(pMe->m_pIDisplay,AEE_FONT_NORMAL,&a,&b);
//绘制背景图
if(pMe->m_pImageBk)
...{
IIMAGE_SetDrawSize(pMe->m_pImageBk,pMe->m_Rect.dx,pMe->m_Rect.dy);
IIMAGE_Draw(pMe->m_pImageBk,pMe->m_Rect.x,pMe->m_Rect.y);
}
//确定菜单高度
if(pMe->m_pImageSe)
...{
IIMAGE_GetInfo(pMe->m_pImageSe,&infSe);
IIMAGE_SetDrawSize(pMe->m_pImageSe,pMe->m_Rect.dx,infSe.cy);
}
//绘制菜单项
i=0;
j=0;
height=pMe->m_Rect.y;
while(p)
...{
if(i<pMe->m_startIndex)
...{
p=p->pNext;
i++;
continue;
}
if(j>=pMe->m_pageSize)
...{
break;
}
pData=(GMenuItem*)p->pData;
if(i==pMe->m_Index)
...{
IIMAGE_Draw(pMe->m_pImageSe,pMe->m_Rect.x,height);
ZEROAT(&infIc);
if(pData->pImage)
...{
IIMAGE_GetInfo(pData->pImage,&infIc);
IIMAGE_Draw(pData->pImage,pMe->m_Rect.x,height+(infSe.cy-infIc.cy)/2);
}
xx=pMe->m_Rect.x+infIc.cx;
yy=height+(infSe.cy-h)/2;
dxx=pMe->m_Rect.x+pMe->m_Rect.dx-xx;
dyy=h;
SETAEERECT(&rec,xx,yy,dxx,dyy);
oldColor = IDISPLAY_SetColor(pMe->m_pIDisplay,CLR_USER_TEXT,pMe->m_Colors.cSelText);
if(pMe->m_Properties&0x02)
IDISPLAY_DrawText(pMe->m_pIDisplay,AEE_FONT_NORMAL,pData->pText+pMe->m_textPos,-1,xx+1,yy,&rec,IDF_TEXT_TRANSPARENT);
IDISPLAY_DrawText(pMe->m_pIDisplay,AEE_FONT_NORMAL,pData->pText+pMe->m_textPos,-1,xx,yy,&rec,IDF_TEXT_TRANSPARENT);
if(pMe->m_isActive)
...{
if(IDISPLAY_MeasureText(pMe->m_pIDisplay,AEE_FONT_NORMAL,pData->pText)>dxx)
...{
if(IDISPLAY_MeasureText(pMe->m_pIDisplay,AEE_FONT_NORMAL,pData->pText+pMe->m_textPos)>dxx)
...{
pMe->m_textPos++;
}
else
pMe->m_textPos=0;
ISHELL_SetTimer(pMe->m_pIShell,300,(PFNNOTIFY)IGMenuCtl_Redraw,(void*)pMe);
}
}
height+=infSe.cy;
IDISPLAY_SetColor(pMe->m_pIDisplay,CLR_USER_TEXT,oldColor);
}
else
...{
ZEROAT(&infIc);
if(pData->pImage)
...{
IIMAGE_GetInfo(pData->pImage,&infIc);
IIMAGE_Draw(pData->pImage,pMe->m_Rect.x,height+(infSe.cy-infIc.cy)/2);
}
xx=pMe->m_Rect.x+infIc.cx;
yy=height+(infSe.cy-h)/2;
dxx=pMe->m_Rect.x+pMe->m_Rect.dx-xx;
dyy=h;
SETAEERECT(&rec,xx,yy,dxx,dyy);
oldColor = IDISPLAY_SetColor(pMe->m_pIDisplay,CLR_USER_TEXT,pMe->m_Colors.cText);
if(pMe->m_Properties&0x01)
IDISPLAY_DrawText(pMe->m_pIDisplay,AEE_FONT_NORMAL,pData->pText,-1,xx+1,yy,&rec,IDF_TEXT_TRANSPARENT);
IDISPLAY_DrawText(pMe->m_pIDisplay,AEE_FONT_NORMAL,pData->pText,-1,xx,yy,&rec,IDF_TEXT_TRANSPARENT);
height+=infSe.cy;
IDISPLAY_SetColor(pMe->m_pIDisplay,CLR_USER_TEXT,oldColor);
}
p=p->pNext;
i++;
j++;
}
IDISPLAY_Update(pMe->m_pIDisplay);
return TRUE;
}
上面代码中稍要注意的一点是,如果这个选中项的文字比较长,则需要提供滚动效果(IMenuCtl是提供了的)。一句话,加一个定时器ISHELL_SetTimer(pMe->m_pIShell,300,(PFNNOTIFY)IGMenuCtl_Redraw,(void*)pMe);即可。m_textPos就是用来控制当前字串显示的截取位置。
至此,主要的功能就搞定了,那些AddItem、AddItemEx、SetImageBk和SetImageSe都很简单。
发表评论
-
手机开发平台指南、教程和资料介绍(转载)
2009-05-13 15:58 2622欢迎转载,转载请注明出处。作者:手机即信息 博客:http:/ ... -
Brew中的Module的实现方法
2009-05-13 14:36 1249Brew中的Module的实现方法: 【原创作者:sho ... -
Brew常见错误整理
2009-05-07 16:26 12891.用户是否可以将信息上传到开发商的服务器上来?用户传上来 ... -
BREW-教你设计用户界面
2009-04-24 16:14 1996这个书高通下的pdf, ... -
AppLoader的使用
2009-04-24 16:12 2697AppLoader是Brew Tools Suite3.0. ... -
程序在模拟器中的调试
2009-04-24 16:11 1254通过高通的FAQ知道:DBGPRINTF可以在vc的调试窗口和 ... -
程序在手机上的调试
2009-04-24 16:11 1107仍然通过高通的FAQ知道:DBGPRINTF的内容,当 ... -
浅谈ISocket的使用
2009-04-24 16:10 1823环境:brew sdk3.0中文版 + vc6.0 ... -
WEBOPT中http代理的设置
2009-04-24 16:09 1215原代码如下: awo[i].nId = WEBOPT_ ... -
强大的IWEB接口
2009-04-24 16:08 2130概述 本文着重介绍了在1.1SDK中引入的IWEB接口,以及 ... -
关于音频的播放
2009-04-24 16:06 1485先了解一下brew中可以 ... -
关于文件的读写
2009-04-24 16:05 2287brew中对文件操作需要 ... -
界面在手机和模拟器上显示的差异
2009-04-24 16:04 1761高通告诫我们:程序一定要多多在手机上调试。 刚入门时 ... -
在BREW中实现自己的GUI(8)-IWEB的封装
2009-04-13 17:43 2066封装IWeb其实并不算是GUI的范畴,但是一并说了罢。在BRE ... -
在BREW中实现自己的GUI(7)-动态效果的实现
2009-04-13 17:41 1787今天讨论关于GUI的另一个话题:如何在两个界面切换中表现出比较 ... -
在BREW中实现自己的GUI(6)-单选框与复选框的实现
2009-04-13 17:40 1574还有一个常用的UI控件是单选框与复选框。可惜BREW也不提供, ... -
在BREW中实现自己的GUI(5)-滚动条的实现
2009-04-13 17:38 1299前面做IGStatic时我们用到了一个滚动条组件IGScrol ... -
在BREW中实现自己的GUI(4)-IGStatic的实现
2009-04-13 17:37 1617BREW中的IStatic可以方便地显示一个文本,但是它没有背 ... -
在BREW中实现自己的GUI(3)-做一个跑马灯的效果
2009-04-13 17:37 1687有时如果我们在应用中需要提供一个滚动的信息提示条(类似于页面上 ... -
在BREW中实现自己的GUI(2)-TabPane的实现
2009-04-13 17:35 1303同样是定义一下几个实体结构: //自定义菜单项type ...
相关推荐
在《BREW开发-海信(王宏兵).pdf》这本书中,作者深入探讨了BREW平台的游戏开发技术,包括如何使用BREW API进行图形、声音、输入控制等关键模块的编程,以及如何优化性能以适应有限的移动设备资源。 Wordware....
深入BREW开发(1-8)+深度剖析BREW实现原理 BREW,全称为Binary Runtime Environment for Wireless,是由高通公司开发的一种操作系统平台,主要用于移动设备,尤其是早期的CDMA网络手机。它提供了一个用于开发和运行...
此外,线程同步对于多任务环境中的程序设计至关重要,书中的内容将指导读者如何在BREW中实现线程安全的代码。 3. BREW底层原理: BREW的底层实现涉及到操作系统接口、硬件抽象层以及设备驱动。书中的剖析部分会讲解...
### 深度剖析BREW实现原理 #### 一、引言 随着移动通信技术的飞速发展,用户对移动设备的功能需求日益增加。在PC领域,Windows等操作系统以其强大的功能支持了各种应用程序的开发与运行,使得用户可以根据自身需求...
在调试过程中,使用BREW模拟器可以快速测试应用功能和性能,调整代码优化用户体验。 8. 进阶开发: 高级BREW开发者还可以利用扩展API(如Multimedia、Location等)实现更多功能,如多媒体播放、位置服务等。此外,...
描述:本文深入解析了brew接口如何在C语言中实现面向对象编程,并将其与C++面向对象特性进行对比。通过详细的示例代码和概念讲解,帮助读者理解C语言中面向对象的设计思路和实现机制。 ### 面向对象在C语言中的实现...
【BrewMP Windowed实现】是关于在Brew MP平台上构建具有窗口化界面的应用程序的知识点。Brew MP,全称Binary Runtime Environment for Wireless Mobile Platform,是由高通公司开发的一个强大的移动操作系统,主要...
- 该应用程序利用了BREW平台提供的图形显示和用户输入功能,展示了Java应用程序在BREW平台上的运行效果。 #### 3. 技术细节 - **虚拟机的实现**: - 选择合适的内存管理策略,如堆空间的动态调整,以减少内存碎片...
Brew 3.1.5全套开发库安装文件,包括Brew SDK 3.1.5、SDK Tools、Tool Suite、Brew Addins
在这个例子中,你将学习如何使用Brew API进行基本的绘图操作,包括颜色管理、坐标系统和图形变换。这对于创建具有视觉吸引力的应用至关重要。 3. **helloworld**: helloworld是最基础的示例,通常用于验证开发...
在本文中,我们将深入探讨`brew 3.0`的中文API文档,帮助开发者更好地理解和利用这个强大的工具。 `Brew 3.0`是Homebrew的最新版本,它带来了一些重要的改进和新特性。首先,我们来看API接口,API(Application ...
- **单线程运行**:BREW平台的所有应用程序都在同一个单一线程中运行,这意味着所有应用共享相同的内存空间,从而限制了并发处理的能力。这种架构决定了BREW应用的执行模型是基于回调机制的,应用程序本身是由一系列...
- **BREW内核**:分析BREW内核的工作原理及其在系统中的作用。 - **图形系统结构**:深入讲解BREW平台的图形渲染系统结构。 - **高级API应用**:展示如何使用高级BREW接口开发复杂功能。 #### 四、书籍特点 - **...
在这个项目中,“基于brew开发的小程序-电话本”是一个毕业生的设计作品,它利用Brew技术创建了一个简单的电话本应用。虽然这个应用的界面可能不够美观,但其核心功能——电话本的保存和排序——已经实现,对于初学...
根据提供的文件信息,我们可以归纳出一系列关于BREW(Binary Runtime Environment for Wireless)应用程序开发的关键知识点。下面将逐一解析这些知识点: ### 第一章 BREW程序 #### BREW SDK的安装与使用 - **...
1. Cask简介:Homebrew Cask提供了一个命令行接口,用于安装和管理Mac的图形化应用程序。 2. 安装Cask:在安装Brew后,Cask通常已被包含,但可以通过`brew install caskroom/cask`确保最新版本。 3. 使用Cask:安装...
BREW模块概念是指在BREW环境中,应用程序通常被组织成一系列可重用的模块。这些模块各自负责特定的功能,比如图形渲染、网络通信等,可以单独编译、调试和更新,增强了代码的可维护性和复用性。开发者可以通过BREW ...