Ho una situazione che non sono in grado di risolvere, spero di ricevere alcuni consigli da voi.Come rendere scorrevole il TextView in LinearLayout, in Android?
La situazione è semplice: dispongo di un LinearLayout in cui dispongo di una vista testo con più righe di testo. L'utente è in grado di trascinare il TextView fino a quando non trova una posizione che gli piace. Ciò che è veramente importante è che TextView può essere parzialmente fuori dal LinearLayout (apparirà tagliato).
Ecco alcuni esempi di codice:
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="top|center_horizontal"
android:clipChildren="false"
android:gravity="center_horizontal|center_vertical"
android:orientation="vertical" >
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:textColor="@color/text_color"
android:textSize="16sp" />
</LinearLayout>
Come si può vedere la LinearLayout ha clipChildren = false per consentire di taglio del testo. Per la TextView Ho impostato un tocco ascoltatore
txt.setOnTouchListener(new View.OnTouchListener() {
int initialX = 0;
int initialY = 0;
@Override
public boolean onTouch(View v, MotionEvent event) {
switch (event.getActionMasked()) {
case MotionEvent.ACTION_DOWN:
initialX = (int) event.getX();
initialY = (int) event.getY();
break;
case MotionEvent.ACTION_MOVE:
int currentX = (int) event.getX();
int currentY = (int) event.getY();
LinearLayout.LayoutParams lp = (LinearLayout.LayoutParams) txt.getLayoutParams();
int left = lp.leftMargin + (currentX - initialX);
int top = lp.topMargin + (currentY - initialY);
int right = lp.rightMargin - (currentX - initialX);
int bottom = lp.bottomMargin - (currentY - initialY);
lp.rightMargin = right;
lp.leftMargin = left;
lp.bottomMargin = bottom;
lp.topMargin = top;
txt.setLayoutParams(lp);
break;
default:
break;
}
return true;
}
});
E qui è il mio problema: Come potete vedere ho impostato tutti i parametri di layout (destra, sinistra, basso, alto margini). Perché ?
1) Se utilizzo solo a sinistra/in alto, il trascinamento è abbastanza fluido, ma il testo viene avvolto sul bordo destro invece di essere tagliato. Probabilmente a causa del giusto valore di margine 0.
2) Se utilizzo tutti i margini, il testo viene tagliato come voglio, ma il movimento non è omogeneo, salta solo per pochi pixel.
Come posso risolvere questo?