РЕДАКТИРОВАТЬ: Чтобы сделать этот вопрос не столь неприятным, я продолжил работать над этим и есть что-то, что на самом деле покажу. Я полностью удалил весь предыдущий контент и полностью переписываю свой вопрос.

Моя конечная цель - создать экран MainActivity с несколькими кнопками, каждая из которых выполняет разные действия. Двумя примерами кнопок являются: 1) просмотр информации о сборке устройства и 2) просмотр установленных приложений. Когда кнопка нажата, я хочу, чтобы Activity переключился на RecyclerView и представил эту информацию. Пользователь должен иметь возможность нажать кнопку «Назад» и нажать на другую кнопку.

Я считаю, что у меня есть готовая структура, но не могу понять, как интегрировать функцию для чтения пакетов. Для этого факта, где бы я мог создать сами функции и как я могу передать результаты для просмотра в RecyclerView?

Вот "MainActivity.java":

package com.emil.proofofconcepts.anothergo;

import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;

import android.os.Bundle;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity {

    private static final String TAG = "MainActivity";

    //Variables
    private TextView mTv;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        initRecyclerView();
    }

    private void initRecyclerView() {
        RecyclerView recyclerView = findViewById(R.id.recycler_view);
        RecyclerViewAdapter adapter = new RecyclerViewAdapter(this, mTv);
        recyclerView.setAdapter(adapter);
        recyclerView.setLayoutManager(new LinearLayoutManager(this));
    }

}

Это мой "RecyclerViewAdapter.java":

package com.emil.proofofconcepts.anothergo;

import android.content.Context;
import android.content.pm.ApplicationInfo;
import android.content.pm.PackageManager;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.RelativeLayout;
import android.widget.TextView;

import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;

import org.w3c.dom.Text;

import java.util.ArrayList;

public class RecyclerViewAdapter extends RecyclerView.Adapter<RecyclerViewAdapter.ViewHolder>{

    private static final String TAG = "RecyclerViewAdapter";

    private TextView mTv;
    private Context mContext;

    public RecyclerViewAdapter(Context context, TextView mTv) {
        mTv = mTv;
        mContext = context;
    }

    @NonNull
    @Override
    public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.layout_list, parent, false);
        ViewHolder holder = new ViewHolder(view);
        return holder;
    }

    @Override
    public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
        Log.d(TAG, "onBindViewHolder: called.");

        //holder.tv.setText("what");
        holder.tv.setText(readPackages());

    }

    @Override
    public int getItemCount() {
        return 1;
    }

    public class ViewHolder extends RecyclerView.ViewHolder {

        TextView tv;
        RelativeLayout parentLayout;

        public ViewHolder(@NonNull View itemView) {
            super(itemView);
            tv = itemView.findViewById(R.id.tv_display);
            parentLayout = itemView.findViewById(R.id.parent_layout);
        }
    }

    private String readPackages() {
        PackageManager pm = getPackageManager();
        String ret = "";
        for (ApplicationInfo app : pm.getInstalledApplications(0)){
            if(app.className != null && !app.className.equals("Null")){
                if(!ret.equals("")) ret = ret + "\n";
                ret = ret + app.className;
            }
        }
        return ret;
    }

}

Вот мой "layout_list.xml":

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    android:id="@+id/parent_layout"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/tv_display"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Sample Text"/>

</RelativeLayout>

И последнее, но не менее важное, это мой "activity_main.xml":

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/recycler_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scrollbars="vertical">
    </androidx.recyclerview.widget.RecyclerView>

</RelativeLayout>
-1
emilhozan 10 Дек 2019 в 22:54
Хорошо, я нашел эту ссылку: vogella.com/tutorials/AndroidRecyclerView/…, но пример кода не работает как есть.
 – 
emilhozan
11 Дек 2019 в 00:20
Я решил свой вопрос. Нет необходимости использовать RecyclerView. TextView действительно может прокручиваться - не обращайте внимания на этот пост. stackoverflow.com/questions/1748977/…
 – 
emilhozan
11 Дек 2019 в 04:05

1 ответ

Кажется, TextView действительно может прокручиваться. Попробовал еще немного погуглить и нашел следующее: Создание прокрутки TextView на Android

Я потратил довольно много времени здесь и потерял немного ТАКОГО красного :(

0
emilhozan 11 Дек 2019 в 04:07