11

在我的应用程序中,我经常依赖自定义构建视图,例如以下示例。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" 
android:background="@color/light_grey"
android:layout_height="match_parent" 
android:layout_width="fill_parent" >

<TextView 
 style="@style/CardTitle" 
 android:id="@+id/card_title"
 android:layout_height="wrap_content" 
 android:layout_width="fill_parent"      
 />  

<com.whiterabbit.cards.ui.AspectRatioImageView
    android:id="@+id/card_picture"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:adjustViewBounds="true"
    android:layout_marginLeft="30dip"
    android:layout_marginRight="30dip"       
    android:src="@drawable/boss"
    />



<ListView 
    android:id="@+id/card_properties" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content"

/>

问题是,我不知道它是否会正确显示,直到我在真实设备或模拟器上运行它。此外,如果我发现有问题,我将不得不对其进行更改并再次部署应用程序以查看更改是否按预期工作。

这可能是一个漫长而无聊的过程,特别是如果应用程序需要一些交互才能到达您要检查的活动。

使用可视化编辑器不起作用,因为它无法加载自定义视图。

是否有另一种方法可以检查视图的显示方式,而无需在整个应用程序中运行?

4

3 回答 3

56

您可以在自定义视图中执行此操作:

if(!isInEditMode()){
   // Your custom code that is not letting the Visual Editor draw properly
   // i.e. thread spawning or other things in the constructor
}

http://developer.android.com/reference/android/view/View.html#isInEditMode()

这允许您从 ADT 插件 XML 查看器中隐藏代码,并希望向您显示一个布局!

View.isInEditMode()

指示此视图当前是否处于编辑模式。当在开发人员工具中显示时,视图通常处于编辑模式。例如,如果此视图是由可视化用户界面构建器绘制的,则此方法应返回 true。如果子类的正常行为可能会干扰宿主环境,则子类应检查此方法的返回值以提供不同的行为。例如:类在其构造函数中生成一个线程,绘图代码依赖于特定于设备的功能等。此方法通常在自定义小部件的绘图代码中检查。

于 2012-05-24T19:22:02.147 回答
0

您可以创建一个框架活动,该活动仅加载您想要查看的视图并使用足够的数据填充它以使其显示。

于 2012-05-24T18:40:14.057 回答
0

我正在使用 Android Studio,所以我不确定这个答案是否适用于您的情况。

我认为您可以在自定义视图中覆盖 onDraw 方法,例如保持内部图像的纵横比:

@Override
protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);
    // TODO: consider storing these as member variables to reduce
    // allocations per draw cycle.
    int paddingLeft = getPaddingLeft();
    int paddingTop = getPaddingTop();
    int paddingRight = getPaddingRight();
    int paddingBottom = getPaddingBottom();

    int w = getWidth() - paddingLeft - paddingRight;
    int h = getHeight() - paddingTop - paddingBottom;

    w = w<h ? w : h;
    h = w;

    // Draw the example drawable on top of the text.
    if (dieDrawable != null) {
        dieDrawable.setBounds(paddingLeft, paddingTop,
        paddingLeft + w, paddingTop + h);
        dieDrawable.draw(canvas);
    }
}

此方法在模拟器和设计器中都运行。

它也适用于任何重绘视图的事件(onSizeChanged、onLayout 等...)

于 2015-06-16T08:56:34.160 回答