1

ここの VerticalTextView コードに基づいてListView、テキストを垂直にする があります(2 番目の例)。うまく機能していると思っていましたが、スクロールし始めたところ、これらの大きなギャップが現れていることに気付きました。ビューのリサイクルが原因だと思いますが、修正方法がわかりません。私の理論では、古いビューを使用してテキストを更新しますが、ビュー全体のサイズは更新しません。何かご意見は?ListView

左側には、ロードされたときの初期ビューが表示されます。見栄えがします。しかし、下にスクロールして戻ると、これが起こります。

初期ビュー - 良さそう! 2 番目のビュー - 見栄えが悪いです。

VerticalTextView便宜上、ここにコードを投稿します

public class VerticalTextView extends TextView{
   final boolean topDown;

   public VerticalTextView(Context context, AttributeSet attrs){
      super(context, attrs);
      final int gravity = getGravity();
      if(Gravity.isVertical(gravity) && (gravity&Gravity.VERTICAL_GRAVITY_MASK) == Gravity.BOTTOM) {
         setGravity((gravity&Gravity.HORIZONTAL_GRAVITY_MASK) | Gravity.TOP);
         topDown = false;
      }else
         topDown = true;
   }

   @Override
   protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec){
      super.onMeasure(heightMeasureSpec, widthMeasureSpec);
      setMeasuredDimension(getMeasuredHeight(), getMeasuredWidth());
   }

   @Override
   protected void onDraw(Canvas canvas){
      TextPaint textPaint = getPaint(); 
      textPaint.setColor(getCurrentTextColor());
      textPaint.drawableState = getDrawableState();

      canvas.save();

      if(topDown){
         canvas.translate(getWidth(), 0);
         canvas.rotate(90);
      }else {
         canvas.translate(0, getHeight());
         canvas.rotate(-90);
      }


      canvas.translate(getCompoundPaddingLeft(), getExtendedPaddingTop());

      getLayout().draw(canvas);
      canvas.restore();
  }
}

編集: MATCH_PARENT オプションと関係があるようです。WRAP_CONTENT に変更すれば問題ありません。

4

0 に答える 0