0

我正在尝试制作一个显示在微调器中选择的吉他和弦的应用程序。

因此,我制作了吉他琴颈的大图像和几个小点图像,位于琴颈的音柱上。为了显示不同的和弦,我只是将正确的点设置为可见而其他点不可见。到目前为止,一切都很好。

我现在的问题是如何ImageView在使用其他分辨率不同的设备时将点保持在大的正确位置。

在这里您可以看到问题:

这是我的布局文件:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/background" >

    <ImageButton
        android:id="@+id/back"
        android:layout_width="150dp"
        android:layout_height="40dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginRight="0dp"
        android:background="@drawable/back"
        android:contentDescription="back"
        android:text="@string/Lagerfeuer" />

    <ImageView
        android:layout_width="fill_parent"
        android:layout_height="40dp"
        android:layout_alignTop="@id/back"
        android:layout_toRightOf="@id/back"
        android:background="@drawable/back2"
        android:contentDescription="back2" />

    <TextView
        android:layout_width="100dp"
        android:layout_height="40dp"
        android:layout_alignLeft="@id/back"
        android:layout_alignParentTop="true"
        android:layout_marginLeft="25dp"
        android:layout_marginTop="12dp"
        android:text="@string/Lagerfeuer"
        android:textColor="#b4b4b4"
        android:textSize="12dp" />

    <Spinner
        android:id="@+id/chordSpinner"
        android:layout_width="fill_parent"
        android:layout_height="40dp"
        android:layout_alignParentBottom="true" />

    <ImageView
        android:id="@+id/griffbrett"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_above="@id/chordSpinner"
        android:layout_marginBottom="200dp"
        android:adjustViewBounds="true"
        android:src="@drawable/griffbrett" />

    <ImageView
        android:id="@+id/c11"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignTop="@id/griffbrett"
        android:layout_marginLeft="13dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c21"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c11"
        android:layout_below="@id/c11"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c31"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c11"
        android:layout_below="@id/c21"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c41"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c11"
        android:layout_below="@id/c31"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c51"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c11"
        android:layout_below="@id/c41"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c61"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c11"
        android:layout_below="@id/c51"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c12"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignTop="@id/c11"
        android:layout_marginLeft="22dp"
        android:layout_toRightOf="@id/c11"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c22"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c12"
        android:layout_below="@id/c11"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c32"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c12"
        android:layout_below="@id/c21"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c42"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c12"
        android:layout_below="@id/c31"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c52"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c12"
        android:layout_below="@id/c41"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c62"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c12"
        android:layout_below="@id/c51"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c13"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignTop="@id/c11"
        android:layout_marginLeft="22dp"
        android:layout_toRightOf="@id/c12"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c23"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c13"
        android:layout_below="@id/c11"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c33"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c13"
        android:layout_below="@id/c21"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c43"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c13"
        android:layout_below="@id/c31"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c53"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c13"
        android:layout_below="@id/c41"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c63"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c13"
        android:layout_below="@id/c51"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c14"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignTop="@id/c11"
        android:layout_marginLeft="22dp"
        android:layout_toRightOf="@id/c13"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c24"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c14"
        android:layout_below="@id/c11"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c34"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c14"
        android:layout_below="@id/c21"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c44"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c14"
        android:layout_below="@id/c31"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c54"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c14"
        android:layout_below="@id/c41"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c64"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c14"
        android:layout_below="@id/c51"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c15"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignTop="@id/c11"
        android:layout_marginLeft="22dp"
        android:layout_toRightOf="@id/c14"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c25"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c15"
        android:layout_below="@id/c11"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c35"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c15"
        android:layout_below="@id/c21"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c45"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c15"
        android:layout_below="@id/c31"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c55"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c15"
        android:layout_below="@id/c41"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/c65"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignLeft="@id/c15"
        android:layout_below="@id/c51"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/s1"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignParentLeft="true"
        android:layout_alignTop="@id/c11"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/s2"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignParentLeft="true"
        android:layout_below="@id/c11"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/s3"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignParentLeft="true"
        android:layout_below="@id/c21"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/s4"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignParentLeft="true"
        android:layout_below="@id/c31"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/s5"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignParentLeft="true"
        android:layout_below="@id/c41"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

    <ImageView
        android:id="@+id/s6"
        android:layout_width="10dp"
        android:layout_height="10dp"
        android:layout_alignParentLeft="true"
        android:layout_below="@id/c51"
        android:layout_marginTop="2dp"
        android:src="@drawable/dot"
        android:visibility="invisible" />

</RelativeLayout>

我知道,这可能不是进行这种布局的最佳解决方案,而且我不希望您完全浏览这个长 XML 文件,但也许有人可以给我一个建议,告诉我如何更轻松地解决这个问题。

谢谢转发!

4

1 回答 1

0

使用 xml 布局来做到这一点需要做很多工作。我的意见是您创建一些自定义视图,并实现 onMeasure() 和 onDraw 方法。您可以在 onMeasure() 中设置视图高度,并在 onDraw() 方法中绘制这些点。有一个很好的实现你自己的自定义视图的教程
http://developer.android.com/training/custom-views/index.html

如果您真的想在 xml 布局中执行此操作,有一种方法:您可以通过以下方式获取屏幕的高度和宽度

Display display = getWindowManager().getDefaultDisplay(); 
int width = display.getWidth();  // deprecated
int height = display.getHeight();  // deprecated

通过准确计算屏幕的宽度和高度,相应地设置布局中每个 imageView 的 LayoutParams。

于 2013-03-12T09:24:49.333 回答