日期:2014-05-20  浏览次数:20753 次

怎樣在手機中顯示二行二列的圖片,并在每張圖片前加一下單選按鈕?
如:有圖片1,2,3,4
想在界面上顯示效果如下。

o1     o2
o3     o4

其中的o是單選按鈕。

謝謝!

或者是顯示二行二列的四張圖片,選擇其中一個圖片后在那個圖片中顯示“選擇”這二個字。


------解决方案--------------------
用低级界面
------解决方案--------------------
思想是用canvas画出四张图片,包括每张图片前面的未选中的图片o,设置初始焦点位置为第一张图片,如果有图片被选中,把选中图片@覆盖在未选中图片上,并且计算图片后面位置g.drawString() "选择 "。
在paint(Graphics g)方法里画图片,并且确定焦点,定义location,place,当location==place时即为获得焦点
移动焦点调用如下: public void keyPressed(int keycode){
switch(getGameAction(keycode)){
case Canvas.DOWN:
location--;
place--;
}
}
------解决方案--------------------
使用Canvas自己画,然后使用Canvas类中keyPressed函数处理用户的按键事件。
------解决方案--------------------
还不如这样,画一个像鼠标一样的东东,然后用setClip 分别画1,2,3,4
当按键时,更新鼠标坐标,使其指向需要选定的图片...当图片被指向时,再在图片背后画一层框醒目提示..不是要 "性感 "得多吗^_^
------解决方案--------------------
完全达到这种需求和布局得用低级界面自己画了.
既然是低级界面,自然没有单选框这种控件可用.
所以得自己画单选框的样子,自己控制单选框的行为.细节还是挺多的.
------解决方案--------------------
cxc014(有心插柳柳不活,无心栽花花开花?)

还不如这样,画一个像鼠标一样的东东,然后用setClip 分别画1,2,3,4
当按键时,更新鼠标坐标,使其指向需要选定的图片...当图片被指向时,再在图片背后画一层框醒目提示..不是要 "性感 "得多吗^_^

-----------------------------------------------
哈哈,是挺性感的啊.我按照你的做了个demo.你看看是这种效果嘛?


//MainMidlet.java
import javax.microedition.midlet.*;
import javax.microedition.lcdui.*;

public class MainMidlet extends MIDlet {
private static MainMidlet instance;
private Displayable nowScreen;
private Display display;

public MainMidlet() {
instance = this;
nowScreen = new CanvasTest();
}

public void startApp() {
display = Display.getDisplay(this);
display.setCurrent(nowScreen);
}

public void pauseApp() {
nowScreen = display.getCurrent();
}

public void destroyApp(boolean unconditional) {
}

public static void quitApp() {
instance.destroyApp(true);
instance.notifyDestroyed();
instance = null;
}
}

------------------------------------------------
//CanvasTest.java
import javax.microedition.lcdui.*;

public class CanvasTest extends Canvas implements CommandListener {
private Image screen;
private Graphics bufferG;
private int borderX = 5;
private int borderY = 5;
private int mouseX = 15;
private int mouseY = 15;

public CanvasTest() {
screen = Image.createImage(getWidth(),getHeight());

addCommand(new Command( "退出 ", Command.EXIT, 1));
setCommandListener(this);
}

public void commandAction(Command _command, Displayable _displayable) {
if (_command.getCommandType() == Command.EXIT) {
MainMidlet.quitApp();
}
}

protected void paint(Graphics g) {
//缓冲清屏
bufferG = screen.getGraphics();
bufferG.setColor(0x00FFFF00);
bufferG.fillRect(0, 0, getWidth(), getHeight());

//画四个图片
bufferG.setColor(0x000000FF);
bufferG.fillRect(10, 10, 40, 30);