Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

cristianomg

Ajuda com click FloatingActionButton

Recommended Posts

Bom estou iniciando em android, e  cheguei até o ponto onde quero implementar um FloatingActionButton , que ao clicar neste botão eu seja direcionado a uma nova activity de cadastro por exemplo.

Eu tenho estudado e desenvolvido com fragmentos que possuem seu adapter e gero a lista de dados com recyclerView, ok o contexto é este.

Agora eu queria saber onde coloco e como implemento que este meu FloatingActionButton ao clicar nele eu seja direcionado a outra activity

 

Vou deixar aqui meu codigo das intereções e em maiusculo o que foz pro botão floating, não sei se é o local certo para fazer esta chamado, pois fiquei confuso com o que li e estudei sobre o assunto.

 

Meu ADAPTER

public class TimelineAdapterImagens extends RecyclerView.Adapter<TimelineAdapterImagens.TimelinesHolder>  {

    List<Timeline> listaTimelineImg;
    private View.OnClickListener listener;
    Button btnDetails, btnEditar;
  
  	//AQUI ESTOU CRIANDO O BOTAO
    private android.support.design.widget.FloatingActionButton fab;

    public TimelineAdapterImagens(List<Timeline> listaTimelineImg) {
        this.listaTimelineImg = listaTimelineImg;
    }



    @NonNull
    @Override
    public TimelineAdapterImagens.TimelinesHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {

        View vista = LayoutInflater.from(parent.getContext()).inflate(R.layout.fragment_timeline_item_timeline,parent,false);
         return new TimelineAdapterImagens.TimelinesHolder(vista);
  
  //AQUI EU ENTENDI QUE TERIA A INSTANCIA DO BOTAO PARA O CLICK LOGO ABAIXO
   fab = (android.support.design.widget.FloatingActionButton) getActivity().findViewById(R.id.pink_icon);
       }

    @Override
    public void onBindViewHolder(@NonNull TimelineAdapterImagens.TimelinesHolder holder, int position) {

        holder.nomeUsuario.setText(listaTimelineImg.get(position).getNomeUsuario().toString());
        holder.textoPostagem.setText(listaTimelineImg.get(position).getTextoPostagem().toString());
        holder.idQuantLikes.setText(listaTimelineImg.get(position).getQuantLikes().toString()+" curtiram");
        holder.dataPostagem.setText(listaTimelineImg.get(position).getDataPostagem().toString());

        if(listaTimelineImg.get(position).getImagem() != null){
            holder.idImagem.setImageBitmap(listaTimelineImg.get(position).getImagem());
        }else{
            holder.idImagem.setImageResource(R.drawable.sem_foto);
        }

        holder.setOnClickListeners();
    }


    @Override
    public int getItemCount() {
        return listaTimelineImg.size();
    }

    public class TimelinesHolder extends RecyclerView.ViewHolder implements View.OnClickListener {

        TextView codigoPostagem,nomeUsuario,textoPostagem,idQuantLikes,dataPostagem ;
        ImageView idImagem;
        Button btnDetails,btnEditar;
        Context context;

        public TimelinesHolder(View itemView) {
            super(itemView);

            context = itemView.getContext();
            nomeUsuario     = (TextView) itemView.findViewById(R.id.nomeUsuario);
            textoPostagem   = (TextView) itemView.findViewById(R.id.textoPostagem);
            idQuantLikes      = (TextView) itemView.findViewById(R.id.idQuantLikes);
            dataPostagem    = (TextView) itemView.findViewById(R.id.dataPostagem);
            idImagem =  itemView.findViewById(R.id.idImagem);
        }


  		// AQUI FIZ UM TESTE PARA VER SE AO CLICAR RECEBIA UMA MENSAGEM UE FOI CLICADO PARA SABER SE JA PODERIA IMPLEMENTAR A CHAMADA DE UMA OUTRA ACTIVITY
        @Override
        public void onClick(View v) {
            Toast.makeText(context,"oioiio",Toast.LENGTH_SHORT).show();
        }

        public void setOnClickListeners() {

        }
    }

}

 

 

MINHA ACTIVITY FRAG

 

   public static fragmentoGeraListaTimeline newInstance(String param1, String param2) {
        fragmentoGeraListaTimeline fragment = new fragmentoGeraListaTimeline();
        Bundle args = new Bundle();
        args.putString(ARG_PARAM1, param1);
        args.putString(ARG_PARAM2, param2);
        fragment.setArguments(args);
        return fragment;
    }



    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        if (getArguments() != null) {
            mParam1 = getArguments().getString(ARG_PARAM1);
            mParam2 = getArguments().getString(ARG_PARAM2);
        }
    }






    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
             View vista = inflater.inflate(R.layout.activity_main_time, container, false);
        listaTimeline=new ArrayList<>();

        recyclerTimeline= (RecyclerView) vista.findViewById(R.id.recyclerviewtime);
        recyclerTimeline.setLayoutManager(new LinearLayoutManager(this.getContext()));
        recyclerTimeline.setHasFixedSize(true);

        request= Volley.newRequestQueue(getContext());

        carregarWEBService();

        return vista;

    }



    private void carregarWEBService() {

        // FAÇO A BUSCA DOS MEUS DADOS PARA LISTAR NO RECYCLER - TUDO OK ATE AQUI
        jsonObjectReq = new JsonObjectRequest(Request.Method.GET, url, null, this, this);
        request.add(jsonObjectReq);

    }


    // TODO: Rename method, update argument and hook method into UI event
    public void onButtonPressed(Uri uri) {
        if (mListener != null) {
            mListener.onFragmentInteraction(uri);
        }
    }

    @Override
    public void onAttach(Context context) {
        super.onAttach(context);
        if (context instanceof fragmentoGeraListaTimeline.OnFragmentInteractionListener) {
            mListener = (fragmentoGeraListaTimeline.OnFragmentInteractionListener) context;

        } else {
            throw new RuntimeException(context.toString()
                    + " must implement OnFragmentInteractionListener");

        }
    }

    @Override
    public void onDetach() {
        super.onDetach();
        mListener = null;
    }

    @Override
    public void onErrorResponse(VolleyError error) {
        progresso.hide();
        Toast.makeText(getContext(), "Não foi possível listar " +error.toString() , Toast.LENGTH_SHORT).show();
        Log.i("ERROR", error.toString());
    }

    @Override
    public void onResponse(JSONObject response) {


        progresso.hide();

        Timeline timeline = null;
        JSONArray json = response.optJSONArray("timelineImg");


        try {
            for(int i=0; i<json.length();i++){
                timeline = new Timeline();
                JSONObject jsonObject = null;
                jsonObject = json.getJSONObject(i);
			// AQUI O RETORNO DO MEU OBJETO JSON - TUDO CERTO FUNCIONANDO
                listaTimeline.add(timeline);
            }

            progresso.hide();
            TimelineAdapterImagens adapter = new TimelineAdapterImagens(listaTimeline);
            recyclerTimeline.setAdapter(adapter);



        }catch (JSONException e){
            e.printStackTrace();
            progresso.hide();
            Toast.makeText(getContext(), "Não foi possível listar os dados " +response , Toast.LENGTH_SHORT).show();

        }


    }

    public interface OnFragmentInteractionListener {
        // TODO: Update argument type and name
        void onFragmentInteraction(Uri uri);
    }

 

Agora não sei se a chamada é no meu adapter e se esta no local correto ou se é no meu fragmento :(

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por pashaa
      Como podem ver a google não aceita mais a SDK da unity ads por motivos da empresa
      Então resolvi remover toda a SDK do meu código. Libs,linhas de comando, tudo. e mesmo assim ainda ela acusa que tenho a sdk dentro do meu app
      Já tenho mais ou menos 1 ano programando em android e nunca tinha visto algo sobre ou esse erro persistir já que tirei tudo de dentro do app
      A minha dúvida é, onde estou errando? Onde deixei alguma coisa sobre essa sdk?Que inclusive coloquei pra teste a uns 5 meses atrás e até tinha esquecido dela kk
      Peço que me ajudem dando sugestões de como remover por completo pois eu praticamente reverti o processo de adicionar a SDK e todo tipo de linha relacionada a unity.ads
       

    • Por Fernando Rafael
      Bom dia, estou baixando arquivos que estão em uma hospedagem própria para serem acessados por um aplicativo que estou desenvolvendo (consigo fazer normalmente utilizando os comandos citado mais a baixo), porém os arquivos ficam salvos na pasta padrão de DOWNLOADS do Android, minha intenção não é ficar acumulando estes arquivos no aparelho, ou esperar que o usuário exclua manualmente, gostaria em salva-los em uma pasta interna do aplicativo para que seja possível excluir automaticamente pelo próprio aplicativo, já tentei como alternativa excluir esses arquivos da pasta DOWNLOADS, mas não consegui...
       
      Segue o código que estou usando para baixar os arquivos, queria adaptar para baixar direto na pasta interna do aplicativo, ou como alternativa caso isso não seja possível, conseguir excluir esses arquivos da pasta DOWNLOADS do Android...
       
      String url = "https://www.site.com/arquivo.pdf"; //Arquivo que vou baixar DownloadManager.Request request = new DownloadManager.Request(Uri.parse(url)); request.setDescription("Alguma descrição"); request.setTitle("Algum titulo"); //A notificação de conslusão só esta disponível a partir da API 11 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { request.allowScanningByMediaScanner(); request.setNotificationVisibility(DownloadManager.Request.VISIBILITY_VISIBLE_NOTIFY_COMPLETED); } //Salvando o arquivo no diretório de Downloads request.setDestinationInExternalPublicDir(Environment.DIRECTORY_DOWNLOADS, "arquivo.pdf"); DownloadManager manager = (DownloadManager) getSystemService(DOWNLOAD_SERVICE); manager.enqueue(request);  
    • Por Fernando Rafael
      Bom dia, alguém poderia me ajudar com esse problema? 
       
      Estou fazendo um aplicativo bem simples em que sua única função será criar uma pasta no celular (em local acessível pelo gerenciador de arquivos do usuário), e posteriormente copiar arquivos de outro local ou rede e colocar nesta pasta.
       
      Fiz algumas pesquisas, mas por incrível que pareça não encontrei algo que tenha funcionando. Também tenho dúvidas sobre qual seria o equivalente ao "C:/" do Android.
    • Por rharisonluca
      Bom dia galera.
       
      Vou iniciar uma projeto para a empresa onde eu trabalho, eu não sou desenvolvedor, porém tenho noção e sou formado na área. Abaixo vou explicar o modelo do projeto:
       
      O projeto consiste em um aplicativo para controle de roteirização da frota;
      Cada motorista terá acesso ao app pelo celular com login e senha;
      O encarregado pelo logística terá que ter acesso pelo PC (WEB) onde ele irá direcionar os roteiros para cada motorista, nessa plataforma web ele irá enviar as coletas e entregas que cada motorista terá que fazer.
       
      Basicamente o projeto é esse, preciso de norte para saber o que tenho que estudar para desenvolver esse projeto, qual framework estudar, qual liguagem, etc.
       
      Desde já agradeço, abraços.
       
      Att.
       
    • Por glocatelli
      Boa tarde,

      Preciso desenvolver um app com os parâmetros descritos na tabela e estou com dificuldade de pensar uma forma de fazer isso, pensei em vários "If's" para classificar o conforto térmico, mas como existem resultados que se repetem em mais de uma classificação acabei descartando esse caminho.
      Se possível me deem dicas de como os senhores procederiam =D

×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.