OSG显示文字——自定义显示文字函数

#include <Windows.h>

#include <osg/Geode>

#include <osg/Geometry>

#include <osgText/Text>

#include <osgViewer/Viewer>

#include <locale.h>

#include <osgDB/ReadFile>

void setupProperties(osgText::Text& textObject,osgText::Font* font,float size,const osg::Vec3& pos )

{

 textObject.setFont(font);//

 textObject.setCharacterSize(size);//字体大小
 textObject.setPosition(pos);
 textObject.setColor(osg::Vec4(1.0,1.0,1.0,1.0));
 textObject.setAlignment(osgText::Text::CENTER_BOTTOM);//文字显示方向
 //textObject.setAxisAlignment(osgText::Text::SCREEN);//获取文字对称成方式正对屏幕方向
 //textObject.setCharacterSizeMode(osgText::Text::SCREEN_COORDS);//跟随视角不断变化,离物体越远,文字越大
 textObject.setAutoRotateToScreen(true);//跟随视角不断变化,但离物体越远,文字越小,和现实当中像类似
 textObject.setBackdropType(osgText::Text::OUTLINE);//对文字进行描边
 textObject.setBackdropColor(osg::Vec4(1.0,0.0,0.0,1.0));//描边颜色
 textObject.setDrawMode(osgText::Text::TEXT | osgText::Text::BOUNDINGBOX);//添加文字边框

 textObject.setAxisAlignment(osgText::Text::XZ_PLANE);//获取文字对称成方式

}

void createContent(osgText::Text& textObject,const char* string)

{

    int requiredSize=mbstowcs(NULL,string,0);//如果mbstowcs第一参数为NULL那么返回字符串的数目

    wchar_t* wText=new wchar_t[requiredSize+1];

    mbstowcs(wText,string,requiredSize+1);//由char转换成wchar类型

    textObject.setText(wText);

    delete wText;

}

int main()

{

    setlocale(LC_ALL,".936");// 配置地域化信息

    const char* titleString="木兰辞\n拟古决绝词简友";

    const char* textString={

        "人生若只如初见,何事秋风悲画扇;\n"

        "等闲变却故人心,却道故人心易变;\n"

        "骊山语罢倾销半,夜雨霖铃终不怨;\n"

        "何如薄幸锦衣郎,比翼连枝当日愿。"

    };

    osgText::Font* fontHei=osgText::readFontFile("C:\\WINDOWS\\Fonts\\simhei.ttf");

    osgText::Font* fontKai=osgText::readFontFile("C:\\WINDOWS\\Fonts\\simkai.ttf");

    osg::ref_ptr<osgText::Text> title=new osgText::Text;

    setupProperties(*title,fontHei,20.0f,osg::Vec3(0.0,0.0,0.0));

    createContent(*title,titleString);

    osg::ref_ptr<osgText::Text> text=new osgText::Text;

    setupProperties(*text,fontKai,15.0,osg::Vec3(0.0,0.0,-80.0f));

    createContent(*text,textString);

    osg::ref_ptr<osg::Geode> geode=new osg::Geode;

    geode->addDrawable(osg::createTexturedQuadGeometry(osg::Vec3(-150.0,1.0,-130.0),osg::Vec3(300.0,0.0,0.0),osg::Vec3(0.0,0.0,200.0),1.0,1.0));//创建一个写字板

    geode->addDrawable(title.get());

    geode->addDrawable(text.get());

    osgViewer::Viewer viewer;

    viewer.setSceneData(geode.get());

    return viewer.run();    

}
时间: 2024-11-05 18:52:22

OSG显示文字——自定义显示文字函数的相关文章

自定义绘制android EditText的背景,定义EditText文字的显示样式

EditText可以通过layer-list来绘制背景: <?xml version="1.0" encoding="utf-8"?> <layer-list xmlns:android="http://schemas.android.com/apk/res/android"> <item> <shape android:shape="rectangle" //框为矩形 > &l

关于文字单行显示省略号和多行省略号的写法

CSS里的text-overflow属性能用来控制超长溢出的文字内容的显示方式,超出的文字可以是直接截断.用省略号表示,或用自定义的字符替代. 单行文字显示省略号条件: text-overflow的起作用环境是在一个‘block’状态下的父元素容器里,它的inline子元素上水平方向不能换行(即white-space: nowrap;),这种情况下用text-overflow:ellipsis属性,即可将单行文字超出规定宽度显示省略号. p { white-space: nowrap; widt

文字超出DIV后,隐藏文字并显示...

<html> <head> <style type="text/css"> #cs{width:100px;height:50px;line-height:50px;color:#6699ff;border:1px #ff8000 dashed;overflow:hidden;text-overflow:ellipsis} #cs2{width:200px;height:60px;line-height:20px;color:#6699ff;bord

jQuery hover事件鼠标滑过图片半透明标题文字滑动显示隐藏

1.效果及功能说明 hover事件制作产品图片鼠标滑过图片半透明,标题文字从左到右滑动动画移动显示隐藏 2.实现原理 首先把效果都隐藏,然后定义一个伪类来触发所有的效果,接下来当触发伪类后会有一个遍历停止所有的效果,从新触发效果就是标题的从左边淡出和背景颜色的变化,当鼠标离开图片后触发一个遍历,停止所有动画标题回到原处不见,背景颜色变回原样 主要的方法 $(".section  ul li").hover(function() //伪类的触发 $(this).find(".r

CSS实现Div透明,而显示在上面的文字不透明,但也可看到显示在下面的图片内容

CSS实现Div透明,而显示在上面的文字不透明,但也可看到显示在下面的图片内容,DiV透明其实挺简单,主要是为background定义opacity属性,一般这个是最大值是1,数值越接近1,则越不透明,也就是越小越透明,颜色可以自定义.这样可以让图片上的文字更清淅,在一些图片特效中我们会见到这种效果. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/

js实例_当鼠标移动到某个元素上时在元素下面显示一段提示文字

效果: 当鼠标不在自动登录上时,只显示自动登录这个表单,下面的div提示则隐藏. 当鼠标移动到自动登录这个表单时,则显示下面的div提示,当鼠标移出时再将其隐藏 代码实现与原理: HTML代码: <body> <input type="checkbox" />自动登录 <div id="div1">不要再玩游戏啦!!!</div> </body> CSS代码:给id为div1的元素做一下修饰,并且将其最开始

让TextView里面的文字逐个显示的动画效果实现

最近使用TextView时想要实现里面的文字逐个显示的动画效果,就如同打字一样. 主要实现思想:新建一个TextView的派生类,先将要逐个显示的字符串保存变量 mOriginalStr 中,然后启动新线程,每隔一段时间使用 Handler 类对象的sendEmptyMessage(int what) 方法发送消息,让 Handler 对象将mOriginal中的字符串逐个添加到TextView中进行显示. 代码实现如下: 1 /** 2 * Created by Haoye on 2016/1

如何让div中的文字只显示一行,多余的文字隐藏并加上省略号(超链接形式)

写页面的时候遇到了一个小小的问题,如何让div中一行超链接文字只显示一行,多余的文字隐藏并加上省略号,悬浮时隐藏的文字显示出来?解决问题时发现了css3的一个新标签  text-overflow  ,其属性规定当文本溢出包含元素时发生的事情.语法如下: text-overflow: clip|ellipsis|string; 代码如下: <!DOCTYPE html><html><head><meta http-equiv="Content-Type&q

错误记录seterror的文字不显示

今天开发时遇到个小问题,view.seterror的文字由于和theme重叠而无法显示,以前就遇到过,不过想换种方法. 有人说在style里面加<item name="android:textColorPrimaryInverse">@android:color/primary_text_light</item> <style name="AppBaseTheme" parent="@android:style/Theme.L