2012-07-04 4 views
2

Sample img Привет друзья, в основном я разработчик Android. Я новичок в разработке ежевики. Мне нужно создать настраиваемое текстовое поле с кнопкой изображения.CustomTextbox в Blackberry

в правом углу текстового поля, я хочу, чтобы кнопка маленького изображения и его прослушиватель кликов поле текстового поля должно быть пустым.

Я могу создать текстовое поле, а также нарисовать растровое изображение внутри текстового поля. но я не могу поймать фокус и слушателя на кнопку изображения. помогите мне

Просьба дать некоторое представление и образцы.

Я попытался это ...

MyApp.java Класс:

import net.rim.device.api.ui.UiApplication; 

общественного класса MyApp расширяет UIApplication {

public static void main(String[] args) { 

    MyApp theApp = new MyApp(); 
    theApp.enterEventDispatcher(); 
} 

public MyApp() { 
    pushScreen(new MyScreen()); 
} 

}

MyScreen.java класс:

public final class MyScreen extends MainScreen { 
public MyScreen() { 
    super(Manager.NO_VERTICAL_SCROLL); 
    setTitle("MyTitle"); 

    VerticalFieldManager vfm = new VerticalFieldManager(
      Manager.USE_ALL_HEIGHT | Manager.USE_ALL_HEIGHT); 
    HorizontalFieldManager hfm = new HorizontalFieldManager(
      Manager.USE_ALL_WIDTH); 
    HorizontalFieldManager hfm1 = new HorizontalFieldManager(
      Manager.USE_ALL_WIDTH); 
    customManager ctm = new customManager(Manager.USE_ALL_WIDTH); 

    customManager ctm1 = new customManager(Manager.USE_ALL_WIDTH); 

    hfm.add(ctm); 
    hfm1.add(ctm1); 
    vfm.add(hfm); 
    vfm.add(hfm1); 
    add(vfm); 
} 

}

customManager.java Класс:

public class customManager extends Manager implements FieldChangeListener { 

private Textbox txt; 
private Closebtn cls; 

Bitmap bitmap; 

protected customManager(long style) { 
    super(style); 

    // My Coustem TextBOX 
    txt = new Textbox(300, 100); 
    // My Coustem Button 
    cls = new Closebtn(); 

    cls.setChangeListener(this); 
    add(txt); 
    add(cls); 
} 

protected void sublayout(int width, int height) { 

    setPositionChild(getField(0), 10, 10); 
    layoutChild(getField(0), getField(0).getPreferredWidth(), getField(0) 
      .getPreferredHeight()); 

    setPositionChild(getField(1), 
      getField(0).getWidth() - (getField(1).getWidth()), getField(0) 
        .getHeight()/2 - getField(1).getHeight()/2); 
    layoutChild(getField(1), getField(1).getWidth(), getField(1) 
      .getHeight()); 

    setExtent(width, height); 
} 

public void fieldChanged(Field field, int context) { 
    txt.setText(""); 

} 

}

Textbox.java Класс:

public class Textbox extends Manager { 
private int managerWidth; 
private int managerHeight; 
private int arcWidth; 

private VerticalFieldManager vfm = new VerticalFieldManager(
     NO_VERTICAL_SCROLL | USE_ALL_WIDTH); 
private EditField editField; 
private Bitmap bagBitmap; 

Textbox(int width, int height, long style) { 
    super(style | NO_VERTICAL_SCROLL | NO_HORIZONTAL_SCROLL); 
    managerWidth = width; 
    managerHeight = height; 
    long innerStyle = style & (READONLY | FOCUSABLE_MASK); // at least 
    if (innerStyle == 0) { 
     innerStyle = FOCUSABLE; 
    } 
    editField = new EditField("", "", 10, innerStyle); 

    arcWidth = editField.getFont().getHeight() & 0xFFFFFFFE; // make it even 

    EncodedImage en = EncodedImage.getEncodedImageResource("_text.png"); 

    bagBitmap = Util.getScaledBitmapImage(en, width, height); 
    add(vfm); 
    vfm.add(editField); 
} 

public void setFont(Font font) { 
    super.setFont(font); 
    editField.setFont(font); 
    arcWidth = editField.getFont().getHeight() & 0xFFFFFFFE; 
    updateLayout(); 
} 



Textbox(int width, int height) { 
    this(width, height, 0L); 
} 

public String getText() { 
    return editField.getText(); 
} 

public void setText(String newText) { 
    editField.setText(newText); 
} 

public int getPreferredWidth() { 
    return managerWidth; 
} 

public int getPreferredHeight() { 
    return managerHeight; 
} 

protected void sublayout(int w, int h) { 
    if (managerWidth == 0) { 
     managerWidth = w; 
    } 
    if (managerHeight == 0) { 
     managerHeight = h; 
    } 
    int actWidth = Math.min(managerWidth, w); 
    int actHeight = Math.min(managerHeight, h); 
    layoutChild(vfm, actWidth - arcWidth, actHeight - arcWidth); 
    setPositionChild(vfm, arcWidth/2, arcWidth/2); 
    setExtent(actWidth, actHeight); 
} 

protected void paint(Graphics g) { 

    g.drawBitmap(0, 0, getWidth(), getHeight(), bagBitmap, 0, 0); 

    super.paint(g); 
} 

}

Closebtn.java Класс:

public class Closebtn extends Field { 

private Bitmap bitmap; 

public Closebtn() { 
    super(Manager.FOCUSABLE); 

    EncodedImage en = EncodedImage.getEncodedImageResource("close.png"); 

    bitmap = Util.getScaledBitmapImage(en, 50, 50); 

} 

protected void layout(int width, int height) { 
    setExtent(bitmap.getWidth(), bitmap.getHeight()); 
} 

protected void paint(Graphics graphics) { 
    graphics.drawBitmap(0, 0, bitmap.getWidth(), bitmap.getHeight(), 
      bitmap, 0, 0); 
} 

protected void onFocus(int direction) { 
    bitmap = bitmap; 

} 

protected void onUnfocus() { 
    bitmap = bitmap; 
} 

protected boolean keyChar(char character, int status, int time) { 
    if (character == Characters.ENTER) { 
     clickButton(); 
     return true; 
    } 
    return super.keyChar(character, status, time); 
} 

protected boolean navigationClick(int status, int time) { 
    clickButton(); 
    return true; 
} 

protected boolean trackwheelClick(int status, int time) { 
    clickButton(); 
    return true; 
} 

protected boolean invokeAction(int action) { 
    switch (action) { 
    case ACTION_INVOKE: { 
     clickButton(); 
     return true; 
    } 
    } 
    return super.invokeAction(action); 
} 

public void setDirty(boolean dirty) { 
} 

public void setMuddy(boolean muddy) { 
} 

public void clickButton() { 
    fieldChangeNotify(0); 
} 

}

Util.java Класс:

public class Util { 

public static Bitmap getScaledBitmapImage(EncodedImage image, int width, 
     int height) { 

    if (image == null) { 
     return null; 
    } 

    int currentWidthFixed32 = Fixed32.toFP(image.getWidth()); 
    int currentHeightFixed32 = Fixed32.toFP(image.getHeight()); 

    int requiredWidthFixed32 = Fixed32.toFP(width); 
    int requiredHeightFixed32 = Fixed32.toFP(height); 

    int scaleXFixed32 = Fixed32.div(currentWidthFixed32, 
      requiredWidthFixed32); 
    int scaleYFixed32 = Fixed32.div(currentHeightFixed32, 
      requiredHeightFixed32); 

    image = image.scaleImage32(scaleXFixed32, scaleYFixed32); 

    return image.getBitmap(); 
} 

}

Моя проблема в том, что я не могу добавить больше одного поля здесь Pls помочь мне ..

+0

Вы добавляете оба поля, но только в состоянии увидеть один, потому что в вашем классе 'Textbox', менеджер создан с флагом' USE_ALL_HEIGHT'. Удалите его, и вы сможете увидеть и то, и другое. Также вы забыли добавить кнопки. –

+0

Привет Смит, Могу ли я объяснить немного больше, я удалил USE_ALL_HEIGHT в классе текстового поля, а также добавил текстовое поле и поле кнопки в пользовательском классе менеджера. – prakash

+0

Теперь я прочитал его снова, кажется, что вы забыли добавить hfm1 в VFM. –

ответ

1

Попробуйте этот пользовательский класс:

public class TextFieldWithClear extends HorizontalFieldManager { 
protected HorizontalFieldManager hfmEditTextPanel; 
protected LabelField lblEditText; 
protected EditField textField; 
protected MyImageButton bitmapFieldClear; 
int mHeight; 
int mWidth; 
String mLabel; 

public TextFieldWithClear(String label, int width, int height) { 
    super(FOCUSABLE); 

    Border border = BorderFactory 
      .createSimpleBorder(new XYEdges(2, 2, 2, 2)); 
    this.setBorder(border); 
    Background bg = BackgroundFactory.createSolidBackground(Color.WHITE); 
    this.setBackground(bg); 

    mWidth = width; 
    mHeight = height; 
    mLabel = label; 

    lblEditText = new LabelField(mLabel) { 
     protected void paint(Graphics graphics) { 
      graphics.setColor(0x4B4B4B); 
      super.paint(graphics); 
     } 
    }; 
    add(lblEditText); 

    hfmEditTextPanel = new HorizontalFieldManager(FOCUSABLE 
      | VERTICAL_SCROLL | VERTICAL_SCROLLBAR) { 
     protected void sublayout(int maxWidth, int maxHeight) { 
      maxWidth = mWidth - 30; 
      maxHeight = mHeight; 
      super.sublayout(maxWidth, maxHeight); 
      setExtent(maxWidth, maxHeight); 
     } 
    }; 

    textField = new EditField() { 
     // protected void layout(int width, int height) 
     // { 
     // width = mWidth - 50; 
     // height=35; 
     // super.layout(width, height); 
     // //setExtent(width, height); 
     // } 
    }; 
    hfmEditTextPanel.add(textField); 
    add(hfmEditTextPanel); 
    bitmapFieldClear = new MyImageButton(
      Bitmap.getBitmapResource("btn_delete_normal.png"), 
      Bitmap.getBitmapResource("btn_delete_focused.png")); 
    bitmapFieldClear.setChangeListener(buttonListener); 
    add(bitmapFieldClear); 
} 

public String getText() { 
    String value = ""; 
    if (textField.getText().length() > 0) 
     value = textField.getText(); 
    return value; 

} 

public void setString(String value) { 
    if (value != null) { 
     textField.setText(value); 
    } 
} 

FieldChangeListener buttonListener = new FieldChangeListener() { 
    public void fieldChanged(Field field, int context) { 
     textField.clear(0); 
     textField.setFocus(); 

    } 
}; 
public void onUndisplay() 
{ 
    textField.setEditable(false); 
} 
public void onDisplay() 
{ 
    textField.setEditable(true); 
} 
} 
1

Это не просто сделать только переопределение EditField, так что я бы попробовал:

  • Используйте горизонтальный менеджер (например, HorizontalFieldManager или другой пользовательский менеджер, возможно, с фиксированными ширинами столбцов. У этого менеджера будет два поля внутри: слева - EditField, справа - пользовательское кнопочное поле.
  • Установить Background менеджеру. БГ будет рисовать зеленый фон, а также синюю границу. Вы можете использовать масштабированное растровое изображение (посмотрите на BackgroundFactory.createBitmapBackground).
  • Создайте новый подкласс EditField и переопределите его метод paintBackground, чтобы он ничего не делал. Если он не работает, попробуйте переопределить paint, чтобы он рисовал только текст. Это самая сложная часть.
  • Создание пользовательского подкласса Buttonfield с изображением креста на сером круге. Вы можете прочитать хороший учебник о том, как это сделать here. У вас также есть уже сделанный BitmapButtonField в Advanced Ui Library. Когда кнопка нажата, она будет вызывать EditField.setText("") на EditField.
+0

ok Смит, я пробую свой путь и даю знать – prakash

+0

Я отредактировал свой вопрос ... PLS посмотрел и дал мне свою мысль – prakash