我使用以下内容在布局中显示按钮
<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%小于图标的高度时,它会垂直挤压但不保持纵横比,所以圆形看起来像椭圆形
更新
我尝试了下面的内容,但它崩溃说它不能被强制转换为
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);
仍然看起来像一个椭圆形
已解决,但Icon非常小需要与线条大小相同 标记
答案 0 :(得分:1)
根据文档,您没有使用图标或图像。由于您的目标是平板电脑,因此它们可能属于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)资产应为基线的1.5倍,为72x72像素,x高密度(XHDPI)资产应为基线的2倍,为96x96像素,希望这会有所帮助。
答案 1 :(得分:0)
好的伙计我无法弄清楚如何做到这一点所以我有一个解决方法。我使用以下代码来检测应用程序的安装大小,然后根据手机,平板手机或平板电脑运行不同的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);
}