Можем ли мы определить неизвестное количество кликабельных текстов, которые имеют разные результаты для l oop? - PullRequest
0 голосов
/ 30 марта 2020

Я хочу, чтобы на всех ClickableSpans тосты показывали свой собственный текст. Но что бы я ни писал в Toast в onClick для l oop, все ClickableSpans показывают одинаковый вывод Toast. Вкратце, я просто хочу, чтобы ClickableSpans показывал разные тосты за l oop. Как мне это сделать? Я хочу, чтобы все слова были кликабельными. И когда все слова нажаты, они делают разные вещи. Спасибо за вашу помощь.

public class MainActivity extends AppCompatActivity {
private String[] textArray;
    private String text = "1981 senesinde kuantum bilgisayar fikrini Paul Beniof, Max Planck’ın " +
            "enerjinin sürekli olmadan kesikli değerlerde yer alan m, n, k enerji kuantlarıyla ";

    private Chronometer chronometer;

    private int hold=0;
    private TextView textView;
    private int i;

    private MediaPlayer player;
    private long pauseOffset;
    private boolean running;
    private boolean start=true;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        textArray = text.split(" ");
        final SpannableString ss = new SpannableString(text);
        chronometer = findViewById(R.id.chronometer);
        chronometer.setFormat("Time: %s");
        chronometer.setBase(SystemClock.elapsedRealtime());

        textView = findViewById(R.id.text_view);
        textView.setText(text);
        textView.setTextColor(Color.BLACK);

        final ClickableSpan[] clickableSpans = new ClickableSpan[textArray.length];
        for(i = 0; i<textArray.length; i++){

            clickableSpans[i] = new ClickableSpan() {
                @Override
                public void onClick(View widget) {
                    Toast.makeText(MainActivity.this, "", Toast.LENGTH_LONG).show();
                }

                @Override
                public void updateDrawState(TextPaint ds) {
                    super.updateDrawState(ds);
                    ds.setColor(Color.BLACK);
                    ds.setUnderlineText(false);
                }


            };

            final boolean[] c = {true};

            chronometer.setOnChronometerTickListener(new Chronometer.OnChronometerTickListener() {
                @Override
                public void onChronometerTick(Chronometer chronometer) {

                    if ((SystemClock.elapsedRealtime() - chronometer.getBase()) >= 5000&& c[0]) {
                        for(int i=0; i<textArray.length;i++){
                            ss.setSpan(clickableSpans[i], hold, hold + textArray[i].length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
                            hold+=textArray[i].length();
                            hold++;
                        }
                        start=false;
                        hold=0;
                        textView.setText(ss);
                        textView.setMovementMethod(LinkMovementMethod.getInstance());
                        if (running) {
                            chronometer.stop();
                            pauseOffset = SystemClock.elapsedRealtime() - chronometer.getBase();
                            running = false;
                        }
                        c[0]=false;
                    }
                }
            });
            hold=0;
        }
        i=0;

    }

    public void play(View v) {
        if(start){
            if (!running) {
                chronometer.setBase(SystemClock.elapsedRealtime() - pauseOffset);
                chronometer.start();
                running = true;
            }
        }
    }

    public void stop(View v) {
        Intent intent = new Intent(MainActivity.this, MainActivity.class);
        startActivity(intent);
        finish();
    }
}
...