cocos代码研究(21)Widget子类TextField学习笔记

基础理论

一个接受用户输入的widget。 输入文本的渲染基于TextFieldTTF。 如果你想用系统控制行为,请使用EditBox来替代。继承自 Widget。

代码实践

//与占位符有关
void setPlaceHolder (const std::string &value)
设置占位符。

const std::string & getPlaceHolder () const
获取占位符。

const Color4B & getPlaceHolderColor () const
请求占位符使用颜色。

void setPlaceHolderColor (const Color3B &color)
改变占位符颜色。

void setPlaceHolderColor (const Color4B &color)
改变占位符颜色。

//和文字有关
void setText (const std::string &text)
改变文本内容。

const std::string & getStringValue () const
请求获取文本内容。

void setString (const std::string &text)
改变文本内容。

const std::string & getString () const
请求获取文本内容。

const Color4B & getTextColor () const
请求文本颜色。

void setTextColor (const Color4B &textColor)
改变文本颜色。

void setFontSize (int size)
改变字体大小。

int getFontSize () const
请求获取字体大小。

void setFontName (const std::string &name)
改变字体名称。

const std::string & getFontName () const
请求获取字体名称。

virtual void didNotSelectSelf ()
取消关联输入法编辑器。

void setMaxLengthEnabled (bool enable)
开关最大长度限制。

bool isMaxLengthEnabled () const
请求是否开启了最大长度限制。

void setMaxLength (int length)
改变最大输入长度限制。

int getMaxLength () const
请求最大输入长度。

int getStringLength () const
请求输入字符串长度。

//与触摸事件有关
void setTouchSize (const Size &size)
设置触摸区域大小。 触摸大小用于hitTest。

Size getTouchSize () const
获取当前的触摸区域大小。

void setTouchAreaEnabled (bool enable)
启用或关闭触摸区域。

virtual bool hitTest (const Vec2 &pt, const Camera *camera, Vec3 *p) const override
检查一个点是否在控件的内容空间里。 这个函数是用于检测控件的触摸响应区域。

virtual bool onTouchBegan (Touch *touch, Event *unusedEvent) override
触摸事件开始时的回调函数。

//与输入模式有关
void setPasswordEnabled (bool enable)
开关密码输入模式。

bool isPasswordEnabled () const
请求密码输入模式是否开启。

void setPasswordStyleText (const char *styleText)
改变密码模式下的文本样式。

const char * getPasswordStyleText () const
请求密码模式的文本样式。

bool getInsertText () const
是否开启插入文本模式。

void setInsertText (bool insertText)
开关插入文本模式。

bool getDeleteBackward () const
是否允许回删。

void setDeleteBackward (bool deleteBackward)
开关回删模式。

//位置大小和对齐模式有关
virtual Size getAutoRenderSize ()
获取渲染时的大小。

void setTextAreaSize (const Size &size)
改变文本区域大小。

void setTextHorizontalAlignment (TextHAlignment alignment)
改变文本水平对齐类型。

TextHAlignment getTextHorizontalAlignment () const
获取水平对齐类型。

void setTextVerticalAlignment (TextVAlignment alignment)
改变文本垂直对齐类型。

TextVAlignment getTextVerticalAlignment () const
获取文本垂直对齐类型。

void addEventListenerTextField (Ref *target, SEL_TextFieldEvent selecor)
添加一个监听器,当一些预定义事件发生时进行回调操作。

void addEventListener (const ccTextFieldCallback &callback)
添加一个监听器,当一些预定义事件发生时进行回调操作。

实例:

        // Create the textfield
        TextField* textField = TextField::create("input words here","fonts/Marker Felt.ttf",30);
        textField->ignoreContentAdaptWithSize(false);
        ((Label*)(textField->getVirtualRenderer()))->setLineBreakWithoutSpace(true);
        textField->setContentSize(Size(240, 170));
        textField->setString("input words here");
        textField->setTextHorizontalAlignment(TextHAlignment::CENTER);
        textField->setTextVerticalAlignment(TextVAlignment::CENTER);
        textField->setPosition(Vec2(widgetSize.width / 2.0f, widgetSize.height / 2.0f));
        textField->addEventListener(CC_CALLBACK_2(UITextFieldTest_LineWrap::textFieldEvent, this));
        _uiLayer->addChild(textField);
void UITextFieldTest_LineWrap::textFieldEvent(Ref *pSender, TextField::EventType type)
{
    switch (type)
    {
        case TextField::EventType::ATTACH_WITH_IME:
        {
            TextField* textField = dynamic_cast<TextField*>(pSender);
            Size widgetSize = _widget->getContentSize();
            textField->runAction(MoveTo::create(0.225f,
                                                  Vec2(widgetSize.width / 2.0f, widgetSize.height / 2.0f + 30)));
            textField->setTextHorizontalAlignment(TextHAlignment::LEFT);
            textField->setTextVerticalAlignment(TextVAlignment::TOP);

            _displayValueLabel->setString(StringUtils::format("attach with IME"));
        }
            break;

        case TextField::EventType::DETACH_WITH_IME:
        {
            TextField* textField = dynamic_cast<TextField*>(pSender);
            Size widgetSize = _widget->getContentSize();
            textField->runAction(MoveTo::create(0.175f, Vec2(widgetSize.width / 2.0f, widgetSize.height / 2.0f)));
            textField->setTextHorizontalAlignment(TextHAlignment::CENTER);
            textField->setTextVerticalAlignment(TextVAlignment::CENTER);

            _displayValueLabel->setString(StringUtils::format("detach with IME"));
        }
            break;

        case TextField::EventType::INSERT_TEXT:
            _displayValueLabel->setString(StringUtils::format("insert words"));
            break;

        case TextField::EventType::DELETE_BACKWARD:
            _displayValueLabel->setString(StringUtils::format("delete word"));
            break;

        default:
            break;
    }
}
时间: 2024-10-06 08:41:39

cocos代码研究(21)Widget子类TextField学习笔记的相关文章

cocos代码研究(1)Node学习笔记

理论部分 Node类继承自Ref类,是cocos框架中基础底层的一个封装类,与画面渲染相关的类一般都是继承自该类,例如Scene,Layer,Sprite,Sprite3D,Label,SpriteBatchNode,MenuItem,ClippingNode,DrawNode,ParticleBatchNode, ParticleSystem等都是继承自Node类. 代码部分 父子节点关系API virtual void addChild (Node *child)添加一个子节点到容器内,z-

cocos代码研究(5)Action学习笔记

理论部分 Action类也是cocos核心基础类之一,在游戏中起着非常重要的作用,继承自Ref,被 FiniteTimeAction(有限时间动作), Follow , 以及 Speed 继承. 有限时间动作可以划分成: 即时动作(ActionInstant),即时动作只能够立刻完成的动作,这类动作是在下一帧立刻完成的动作,如设定位置.设定缩放等.把它们包装成动作后,可以与其他动作类组合为复杂动作. 持续动作(ActionInterval),在规定的时间内,执行完成对象属性,位置,特效,序列动作

cocos代码研究(2)Layer学习笔记

auto layer = Layer::create(); /*************华丽分割线*************/ auto layer = LayerColor::create(Color4B(255, 0, 0, 255), 150, 150); /*************华丽分割线*************/ auto layer = LayerGradient::create(Color4B(255, 0, 0, 255), Color4B(255, 255, 0, 255

cocos代码研究(1)sprite学习笔记

各种方法创建Sprite和Animate //图片创建法 参数一:图片资源路径 参数二:Rect选区 auto sprite = Sprite::create("Images/grossini_dance_atlas.png", Rect(x, y, 85, 121)); addChild(sprite); /*************华丽分割线*************/ //BatchNode类纹理创建法 //参数一:纹理图片 参数二:容量(子节点数量上限) auto batchN

cocos代码研究(25)Widget子类PageView学习笔记

基础理论 ListView控件是一个显示滚动项目列表的视图组. 列表项是通过使用addChild或insertDefaultItem插入到列表中的,继承自ScrollView. 代码实践 static ListView * create()创建一个空ListView. void setItemModel (Widget *model)设定一个ListView的模型. 当调用pushBackDefaultItem,该模型将作为一个蓝图,新副本将被插入到ListView控件. void pushBa

cocos代码研究(26)Widget子类RichView学习笔记

理论部分 一个显示多个RichElement的容器类. 我们可以使用它很容易显示带图片的文本,继承自 Widget. 代码实践 static RichText * create ()创建一个空的RichText void insertElement (RichElement *element, int index)在指定位置插入一个RichElement. void pushBackElement (RichElement *element)在容器最后插入一个RichElement. void

cocos代码研究(14)Widget子类Button学习笔记

理论基础 表示一个按钮组件. 按钮可以被按下,或者点击, 并且在按下或者点击之后,可以由用户指定一个动作来执行,继承自 Widget. 代码部分 static Button * create ()创建一个空的按钮. static Button * create (const std::string &normalImage, //正常状态纹理的名字.const std::string &selectedImage="", //选中状态纹理名称.const std::st

cocos代码研究(19)Widget子类ImageView学习笔记

理论基础 显示图片的小控件,继承自 Widget . 代码实践 static ImageView * create()创建一个空的ImageView static ImageView * create(const std::string &imageFileName, //纹理的文件名字.TextureResType texType=TextureResType::LOCAL)根据图片名字创建一个ImageView. void loadTexture (const std::string &

cocos代码研究(16)Widget子类RadioButton学习笔记

理论基础 RadioButton是一种特定类型的两状态按钮,它与复选框相似.它可以 和RadioButtonGroup一起使用,形成一个"组".继承自AbstractCheckButton,AbstractCheckButton继承自Widget. 代码部分 void addEventListener (const ccRadioButtonCallback &callback)注册一个回调函数, 它将在单选按钮被选中或者取消的时候被调用. bool isSelected ()