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

Upgrade do Windows Home para Pro sem formatar

 Há algum tempo que tentava fazer o upgrade do meu Windows 10 da versão Home para a versão Pro, mas chegava sempre a um ponto em que me era solicitado para formatar o sistema e não estava para isso. Finalmente conseguinte seguindo estes passos: - seguinte estes passos  utilizei uma das chaves genéricas para o Windows 10 Pro e fui a Settings > Update & Security > Activation > Change the product key; - após inserir uma das chaves o Windows instala as funcionalidades Pro e pede para reiniciar; - agora tem o Windows Pro mas não está ativado, assim fui ao site urcdkeys  onde comprei uma chave para o Windows Pro por menos de €20; - com essa chave voltei a funcionalidade Change the product key e ativei o Windows; - e pronto, Windows Pro ativado sem formatar ou reinstalar. Importante : eu não tenho nada a ver com o site urcdkeys por isso a vossa experiência pode correr de forma diferente da minha.

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

Tem troco

Para hoje um pequeno programa que dá troco, bem dar não dá mas calcula o troco a dar em função das moedas disponíveis. Neste projeto vamos utilizar o novo Visual Studio 2012. Como era de se esperar vamos iniciar um projeto novo: Agora adicionamos os seguintes elementos:  - um botão para calcular as moedas a dar de troco  - um botão para repor o número de moedas iniciais disponíveis  - uma textbox para introduzir o valor a pagar  - uma textbox para introduzir o valor entregue  - umas labels para informar o utilizador do que deve introduzir e outra para mostrar o troco  - por fim uma grelha para mostrar os valores das moedas e as quantidades disponíveis de cada uma. A janela principal do programa fica assim: Agora o código, primeiro o evento load do formulário, neste vamos definir os valores das moedas e as respetivas quantidades Para guardar estes valores vamos necessitar de uma variável definida ao nível do formulário, logo abaixo da definição da class: Public Class Form1     Public mo