LinearLayout
私は、拡張するカスタムビューTextView
(これを「IdiomView
」と呼び始めます)とを含む単純なものを持っていListView
ます。IdiomView
通常との唯一の違いは、テキストの長さが3行未満になるまで、テキストサイズを繰り返し縮小するメソッドをTextView
オーバーライドしたことです。onDraw()
私の問題は、ビューが描画されると、ユーザーに次のように表示されることです。
______________
|__ACTION_BAR__|
| IdiomView |
|______________|
| |
| ListView |
| |
| |
|______________|
これはすぐになります:
______________
|__ACTION_BAR__|
|__IdiomView __|
| |
| ListView |
| |
| |
| |
|______________|
IdiomView
つまり、ListViewが描画され、サイズが分類された後にジャンプアップします。
私が欲しいのはIdiomView
、ListViewを描画する前に、完全に描画されるまで待つ方法です。この投稿すべてのビューが完全に描画された後に発生するイベントは何ですか?を呼び出して、描画が完了した後にスレッドを整列させる方法を説明しますView.post(Runnable)
。問題は、小さいテキストが3行未満であるかどうかを計算するために、オーバーライドされたonDraw()
メソッド呼び出しが複数回呼び出されることです。したがって、この要素は、表示する前に何度も「描画を終了」する可能性があります。onDraw()
ListView
すべてのコメントと回答に感謝します。これが私の現在のコードです:
レイアウトXML:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/main_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_margin="10dp"
android:background="@color/off_white"
android:orientation="vertical" >
<carter.cwords.idioms.IdiomView
android:id="@+id/idiom"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginBottom="10dp"
android:textColor="@color/transparent"
android:textSize="28sp"
android:textStyle="italic"
android:visibility="invisible" />
<ListView
android:id="@+id/quote_list"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:choiceMode="none"
android:footerDividersEnabled="false"
android:headerDividersEnabled="false"
android:visibility="invisible" />
</LinearLayout>
アクティビティ:
private IdiomView mIdiomTextView;
private ListView mQuoteList;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.idiom_of_the_day);
mIdiomTextView = (IdiomView) findViewById(R.id.idiom);
mQuoteList = (ListView) findViewById(R.id.quote_list);
// Populate page data onResume()
}
@Override
protected void onResume() {
super.onResume();
sendRequest(R.string.url_idiom_of_the_day, new AfterRequest(){
@Override
public void useResults(Document resultXml) {
if(resultXml != null){
Log.i(getClass().getSimpleName(), "useResults()");
String idiomString = XmlUtilities.getTextValue(resultXml, NetworkHelper.XML_TAG_IDIOM_CONTENT);
logDebug("idiomString: " + idiomString);
mIdiomTextView.setText("\"" + idiomString + "\"");
mQuoteList.setAdapter(new ContentAdapter(mContext, resultXml));
mIdiomTextView.setVisibility(View.VISIBLE);
mIdiomTextView.post(new Runnable(){
@Override
public void run() {
mQuoteList.setVisibility(View.VISIBLE);
}
});
}
}
});
}
IdiomView
:
public class IdiomView extends TextView {
public IdiomView(Context context) {
super(context);
}
public IdiomView(Context context, AttributeSet attrs){
super(context, attrs);
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
Log.i(getClass().getSimpleName(), "onDraw(): " + this.getLineCount());
if(this.getLineCount() > 2){
this.setTextSize(TypedValue.COMPLEX_UNIT_PX, this.getTextSize()-1);
}
else{
this.setTextColor(getResources().getColor(R.color.text));
}
Log.i(getClass().getSimpleName(), "onDraw(): " + this.getLineCount());
}
}
どうもありがとうございます。