Avançar para o conteúdo principal

Time's Up com ficheiros

Aparentemente não demorou muito tempo, tal como tinha dito no post anterior seria interessante que os tempos guardados pudessem ser recuperados para sessões posteriores, assim adicionei dois botões à interface.



O botão Gravar vai gravar num ficheiro de texto os dados relativos aos tempos intermédios.
O botão Limpar, tal como o nome indica, apaga os tempos da textview não do ficheiro.

O código


A função associada ao botão Limpar:
    //função para limpar a textview 2
    public void bt_limpar_click(View v){
    tv2.setText("");
    }
Simples, sem comentários.


Agora a função associada ao botão Gravar:

    //gravar no ficheiro os tempos
    public void bt_gravar_click(View v){
    try{
    File myfile = new File(ficheiro);
    myfile.createNewFile();
    FileOutputStream fOut = new FileOutputStream(myfile);
    OutputStreamWriter myOutWriter = new OutputStreamWriter(fOut);
    myOutWriter.append(tv2.getText());
    myOutWriter.close();
    fOut.close();
    showMessage("Gravado com sucesso!");
    }catch (Exception ex){
    showMessage(ex.getMessage());
    }
    }
Nesta função criamos um ficheiro e associamos um Output Stream a esse ficheiro que depois utilizamos para gravar o conteúdo do textView2.

Por fim a função que abre e lê o ficheiro sempre que a aplicação é iniciada:
    //função para ler o ficheiro e adicionar à textview
    public void ler_ficheiro(){
    try{
    File myfile = new File(ficheiro);
    FileInputStream fIn = new FileInputStream(myfile);
    BufferedReader myReader = new BufferedReader(new InputStreamReader(fIn));
   
    String aDataRow="";
    String aBuffer="";
    while((aDataRow=myReader.readLine())!=null){
    aBuffer +=aDataRow + "\n";
    }
    tv2.setText(aBuffer);
    myReader.close();
    showMessage("Tempos carregados!");
    }catch (Exception ex){
   
    }
    }
Esta função é chamada na função onCreate.

Não nos podemos esquecer de adicionar ao manifesto da aplicação a permissão com a seguinte linha:
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

E assim temos um projeto completo, o próximo passo é visual, tenho de começar a ter mais cuidado com a interface, até agora tem sido só atirar botões e textviews para o ecrã e depois se vê.

A nova versão do projeto e da aplicação.

Comentários

Mensagens populares deste blogue

Vamos fazer um carro com o Unity 3D

Neste artigo vamos fazer um carro, simples, com o Unity 3D. A ideia é utilizar o motor de física do Unity 3D para simular o comportamento do carro. Os passos a seguir são: [1] - Criar um projeto novo

C# IEnumerable e IEnumerator

Neste artigo vamos aprender como utilizar a interface IEnumerator por forma a permitir utilizar um ciclo foreach num conjunto ou coleção de dados. A maior parte das coleções (listas e outras) já implementam a interface, mas neste caso vamos personalizar a maneira como percorremos a lista. Quando utilizamos código assim: foreach(Class c in Collection) { ... } O compilador converte este código em algo assim: IEnumerator cc = Collection.GetEnumerator() while(cc.MoveNext()) { c=(Class)cc.Current; ... } Ao implementar a interface IEnumerable significa que a classe implementa uma versão da função GetEnumerator() que deve devolver uma classe que implemente a interface IEnumerator. Vamos explorar um exemplo. Começamos pela classe client Esta classe permitirá guardar os dados dos clientes, existindo um campo para indicar se o cliente ainda está ativo ou não. De seguida temos uma classe que define uma lista de clientes e que implementa a interface IEnumerable que de

React - Introdução

 Neste post vamos fazer uma breve introdução ao React. React é uma framework javascript e por isso é importante ter conhecimentos desta linguagem de programação para melhor compreender o seu funcionamento. O que é necessário? Para construir páginas com React é necessário ter instalado a framework Node e o seu instalador de packages o npm. Com o Node instalado basta abrir uma janela da linha de comandos, eu aconselho utilizar o novo Windows Terminal ou o Cmder . Na sua linha de comando escolhida execute o comando: npx create-react-app Tutorial01 Este comando vai criar uma pasta com o nome Tutorial01 e instalar dos os ficheiros necessários para construir a sua primeira aplicação React dentro dessa pasta. De seguida entramos na pasta criada com o comando: cd Tutorial01 E iniciamos a aplicação com o comando: npm start Deve conseguir ver uma página com o seguinte aspeto: A partir daqui, até fechar a linha de comando, todas as alterações feitas aos ficheiros da sua aplicação são automaticam