繁体   English   中英

Android按钮的宽高比

[英]Android Aspect Ratio of Button

我使用以下内容在布局中显示按钮

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="0dip"
    android:layout_weight="0.2"
    android:gravity="bottom|right"
    android:orientation="vertical" >

    <TableRow
                android:id="@+id/tableRow3"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:gravity="right" >

        <Button
            android:id="@+id/clear"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginRight="20dip"
            android:background="@drawable/butt2"
            android:onClick="clk_clear"
            android:scaleType="centerInside"
            android:textColor="#000000"
            android:textSize="50dp" />

    </TableRow>

   </LinearLayout>

这会将布局设置为可用高度的20%,并在其中放置一个按钮

问题是,当屏幕的20%小于图标的高度时,垂直挤压该图标但不保持宽高比,因此圆形最终看起来像一个椭圆形

UPDATE

我尝试了以下操作,但崩溃后无法将其强制转换为

 android.widget.TableRow$LayouParams

有任何想法吗

Button txt1 = (Button) findViewById(R.id.clear);  
    int btnSize=txt1.getLayoutParams().width;
    txt1.setLayoutParams(new LayoutParams(btnSize, btnSize));

也试过了

    Button txt1 = (Button) findViewById(R.id.clear);  
    int btnSize=txt1.getHeight();
    txt1.setWidth(btnSize);

看起来仍然像椭圆形

样本图片

已解决,但图标很小,需要与线条大小相同

很小

椭圆

您没有根据文档使用图标或图像。 由于您的目标是平板电脑,因此它们可能属于HDPI,XHDPI或XXHDPI。 确保在各个资源文件夹中具有相同名称且大小相同的图像。

通常资源文件夹的结构如下

在此处输入图片说明

您可以在http://developer.android.com/design/style/iconography.html上了解更多信息

该文件明确指出:

当您的应用运行时,Android会检查设备屏幕的特征并为您的应用加载适当的密度特定资产。 要为不同的密度创建图标,您应遵循五个主要密度(分别为中,高,x高,xx高和xxx高)之间的2:3:4:6:8缩放比例。 例如,请考虑将启动器图标的大小指定为48x48 dp。 这表示基准(MDPI)资产为48x48像素,高密度(HDPI)资产应为72x72 px的基准的1.5倍,x高密度(XHDPI)资产应为96x96 px的基准的2倍,等等。

希望这可以帮助。

好的,我无法解决该问题,所以我有一种解决方法。 我使用以下代码来检测应用程序安装在什么尺寸的屏幕上,然后根据其手机,平板手机或平板电脑运行不同的xml布局

这不是一个完美的解决方案,但是除非有人能帮助我做到这一点,否则我将尽力而为。

   DisplayMetrics metrics = new DisplayMetrics();
    getWindowManager().getDefaultDisplay().getMetrics(metrics);
    int widthPixels = metrics.widthPixels;
    int heightPixels = metrics.heightPixels;
    String Textsize = String.valueOf(widthPixels) + " x " + String.valueOf(heightPixels);
    float scaleFactor = metrics.density;
    float widthDp = widthPixels / scaleFactor;
    float heightDp = heightPixels / scaleFactor;
    String Textsize2 = String.valueOf(widthDp) + " x " + String.valueOf(heightDp);
    float smallestWidth = Math.min(widthDp, heightDp);
    float widthDpi = metrics.xdpi;
    float heightDpi = metrics.ydpi;
    float widthInches = widthPixels / widthDpi;
    float heightInches = heightPixels / heightDpi;
    double diagonalInches = Math.sqrt(
            (widthInches * widthInches) 
            + (heightInches * heightInches));

    if (diagonalInches >= 10) {
        //Toast.makeText(getBaseContext(), "Tablet", Toast.LENGTH_LONG).show();
        setContentView(R.layout.mainactivity2);
    } 
    if (diagonalInches >= 5 && diagonalInches <=9){
        //Toast.makeText(getBaseContext(), "Phablet", Toast.LENGTH_LONG).show();
        setContentView(R.layout.mainactivity);
    } 
    if (diagonalInches <= 5) {
        //Toast.makeText(getBaseContext(), "Phone", Toast.LENGTH_LONG).show();
        setContentView(R.layout.mainactivity3);
    } 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM