Поле ключевого фильтра в ежевике - PullRequest
0 голосов
/ 26 декабря 2011

Я использовал фильтр ключевых слов для списка, который заполняется из БД. Работает хорошо. Представьте, что список содержит фразу «Большая летучая мышь», и есть другие слова, начинающиеся с «б», как книги и т. b 'в поле поиска сначала появляется фраза' большая летучая мышь ', а затем только слова, начинающиеся с' b '. Пожалуйста, помогите мне исправить это пожалуйста, смотрите мой код

public final class KeywordFilter 
{
    private KeywordFilterField _keywordFilterField;    
    private WordList _wordList;
    private Vector _words;  


    public KeywordFilter()
    {      

        _words = getDataFromDatabase();

        if(_words != null)
        {

            _wordList = new WordList(_words);        


            _keywordFilterField = new KeywordFilterField();                   
            _keywordFilterField.setSourceList(_wordList, _wordList);      


            CustomKeywordField customSearchField = new CustomKeywordField();
            _keywordFilterField.setKeywordField(customSearchField);                      


            KeywordFilterScreen screen = new KeywordFilterScreen(this);


            screen.setTitle(_keywordFilterField.getKeywordField());            


            screen.add(_keywordFilterField);
             UiApplication ui = UiApplication.getUiApplication();

           ui.pushScreen(screen);

        } 
        else
        {
            UiApplication.getUiApplication().invokeLater(new Runnable()
            {
                public void run()
                {
                    Dialog.alert("Error reading data file.");
                    System.exit(0);
                }
            });
        }       
    }   


    KeywordFilterField getKeywordFilterField()
    {
        return _keywordFilterField;
    }   


    private Vector getDataFromDatabase()
    {   
        Vector words = new Vector();
        Database d;
            for(;;)
            {
                try
                {
                    URI myURI=URI.create("file:///SDCard/Databases/MyTestDatabase.db");
                    d=DatabaseFactory.open(myURI);
                   Statement st=d.createStatement("select (select distinct group_concat(eng) fromEnglish),group_concat(mal) from English e ,Malayalam m where e.Ecode=m.Mcode group by eng");
                   st.prepare();
                   net.rim.device.api.database.Cursor c=st.getCursor();
                   Row r;

                   while(c.next())
                   {

                    r=c.getRow();
                    String w=r.getString(0);
                    String meaning=r.getString(1);

                    words.addElement(new Word(w,meaning));
                   }
                   st.close();
                   d.close();
                   }
                     catch ( Exception e ) 
        {         
            System.out.println( e.getMessage() );
            e.printStackTrace();
        }                      


            return words;           
        }

    } 


    void addElementToList(Word w)
    {       
         _wordList.addElement(w);
        _keywordFilterField.updateList();       
    }   


    final static class CustomKeywordField extends BasicEditField
    {   

        CustomKeywordField()
        {

            super(USE_ALL_WIDTH|NON_FOCUSABLE|NO_LEARNING|NO_NEWLINE); 

            setLabel("Search: ");
        } 


        protected boolean keyChar(char ch, int status, int time)
        {
            switch(ch)
            {
                case Characters.ESCAPE:

                    if(super.getTextLength() > 0)
                    {
                        setText("");                        
                        return true;
                    }

            }                
            return super.keyChar(ch, status, time);
        }                     


        protected void paint(Graphics graphics)
        {            
            super.paint(graphics);


            getFocusRect(new XYRect());
            drawFocus(graphics, true);                          
        }
    }
}



  class KeywordFilterScreen extends MainScreen
{
    private KeywordFilter _app;
    private KeywordFilterField _keywordFilterField;    

    public KeywordFilterScreen(KeywordFilter app)
    {

        _app = app;


        _keywordFilterField = _app.getKeywordFilterField();



    }


    protected boolean keyChar(char key, int status, int time)
     {
         if (key == Characters.ENTER)
        {
           displayInfoScreen();
             // Word w = (Word)_keywordFilterField.getSelectedElement(); 
             // Status.show(w.getMeaning()); 

            return true; 
        }             
        return super.keyChar(key, status, time);
    }    


    public boolean invokeAction(int action)
    {        
        switch(action)
        {
            case ACTION_INVOKE: 

                displayInfoScreen();   

                return true; 
        }    
        return  super.invokeAction(action);
    }


    private void displayInfoScreen()
    {

        Word w = (Word)_keywordFilterField.getSelectedElement(); 
        if(w != null)
        {            
            InfoScreen infoScreen = new InfoScreen(w);
            UiApplication ui=UiApplication.getUiApplication();
            ui.pushScreen(infoScreen);


        }
    }


    public boolean onSavePrompt()
    {
        return true;
    }



    private final static class InfoScreen extends MainScreen
    {

        InfoScreen(Word w)
        {  

            setTitle(w.toString());            
            BasicEditField popField = new BasicEditField(" ",w.getMeaning(),300,Field.NON_FOCUSABLE);

          FontManager.getInstance().load("DC124.TTF", "MyFont", FontManager.APPLICATION_FONT) ;
        {
             try {
                FontFamily typeface = FontFamily.forName("MyFont");
                Font myFont = typeface.getFont(Font.PLAIN, 25);
                popField.setFont(myFont);
                add(popField);
            } catch (ClassNotFoundException ex) {
                ex.printStackTrace();}

            }




        }        
    }       
}

Ответы [ 2 ]

0 голосов
/ 26 декабря 2011

Этот запрос полезен для вас:

ВЫБРАТЬ Имя ОТ Сотрудника, где Имя, например, «% d%», упорядочено по имени;

Здесь Имя - это имя моего столбца;

Попробуйте это;

0 голосов
/ 26 декабря 2011

Я думаю, что вы используете запрос как следующий

select colomname from tablename where colomname GLOB '%b%';

здесь вы получаете все имена, содержащие букву 'b' (с учетом регистра) если вы хотите, чтобы все слова с буквой 'b' использовались, напишите запрос наподобие

  select colomname from tablename where colomname GLOB 'b%' order by colomname ;

здесь я использую «GLOB», он дает регистр с учетом выходных записей, если вам не нужен регистр, тогда вы можете использовать ключевое слово «LIKE»

спасибо

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...