0
我知道這些類型的問題之前已經被問過,但我還沒有看到過這種類型。我正在使用android畫布創建一個自定義的Android UI。我已經創建了所有必要的可繪它,並把它們放在相應的文件夾,現在我使用此代碼繪製UI:自定義的Android用戶界面和多屏幕支持
public class MainMenuView extends View {
private Bitmap pasteImage;
private Bitmap adventureLetters;
private Bitmap settingsLetters;
private Bitmap quitLetters;
private Bitmap backgroundImage;
private DisplayMetrics metrics;
public MainMenuView(Context context){
super(context);
pasteImage = decodeFile(R.drawable.paste, 200, true);
Log.w("Visina imagea", String.valueOf(pasteImage.getHeight()));
pasteImage.recycle();
}
public MainMenuView(Context context, AttributeSet attrSet){
super(context, attrSet);
metrics = context.getResources().getDisplayMetrics();
pasteImage = decodeFile(R.drawable.paste, 330, true);
adventureLetters = decodeFile(R.drawable.adventureletters, 100, true);
settingsLetters = decodeFile(R.drawable.settingsletters, 100, true);
quitLetters = decodeFile(R.drawable.quitletters, 50, true);
Log.w("Je li image null? ", pasteImage == null ? "da" : "ne");
backgroundImage = decodeFileScaled(R.drawable.toothpastebackground);
backgroundImage = Bitmap.createScaledBitmap(backgroundImage, metrics.widthPixels - 20, metrics.heightPixels, true);
//adventureLetters = BitmapFactory.decodeResource(getResources(), R.drawable.adventureletters);
//settingsLetters = BitmapFactory.decodeResource(getResources(), R.drawable.settingsletters);
//quitLetters = BitmapFactory.decodeResource(getResources(), R.drawable.quitletters);
}
@Override
protected void onMeasure(int widthMeasure, int heightMeasure){
setMeasuredDimension(calculateMeasure(widthMeasure), calculateMeasure(heightMeasure));
Log.w(String.valueOf(calculateMeasure(widthMeasure)), "Izmjereno");
}
private static final int DEFAULT_SIZE = 70;
private int calculateMeasure(int measure) {
int result = (int)(DEFAULT_SIZE * getResources().getDisplayMetrics().density);
int specMode = MeasureSpec.getMode(measure);
int specSize = MeasureSpec.getSize(measure);
if(specMode == MeasureSpec.EXACTLY) result = specSize;
else if(specMode == MeasureSpec.AT_MOST){
result = Math.min(result, specSize);
}
return result;
}
@Override
protected void onDraw(Canvas canvas){
super.onDraw(canvas);
if(canvas == null) Log.w("Canvas je null", "Da");
else Log.w("Canvas nije null", "ne");
Log.w("Usao u onDraw", "u onDraw sam sad");
canvas.save();
if(pasteImage == null) Log.w("Slika je null", "null slika");
canvas.drawBitmap(backgroundImage, 0, 0, null);
Log.w("Dimenzije slike sirina x visina bg", backgroundImage.getWidth() + " " + backgroundImage.getHeight());
canvas.drawBitmap(pasteImage, 110, 420, null);
canvas.drawBitmap(adventureLetters, 50, 60, null);
canvas.drawBitmap(settingsLetters, 80, 60, null);
canvas.drawBitmap(quitLetters, 100, 60, null);
pasteImage.recycle();
adventureLetters.recycle();
settingsLetters.recycle();
quitLetters.recycle();
canvas.restore();
}
private Bitmap decodeFile(int id, int size, boolean resize){
//Decode image size
BitmapFactory.Options o = new BitmapFactory.Options();
o.inJustDecodeBounds = true;
BitmapFactory.decodeResource(getResources(), id, o);
//The new size we want to scale to
final int REQUIRED_SIZE = size;
//Find the correct scale value. It should be the power of 2.
int scale = 1;
while(o.outWidth/scale/2 >= REQUIRED_SIZE && o.outHeight/scale/2 >= REQUIRED_SIZE)
scale*=2;
//Decode with inSampleSize
BitmapFactory.Options o2 = new BitmapFactory.Options();
o2.inSampleSize = scale;
return BitmapFactory.decodeResource(getResources(), id, o2);
}
private Bitmap decodeFileScaled(int id){
final BitmapFactory.Options options = new BitmapFactory.Options();
options.inJustDecodeBounds = true;
BitmapFactory.decodeResource(getResources(), id, options);
Log.w("Sirina x visina displaya", metrics.widthPixels + "x" + metrics.heightPixels);
options.inSampleSize = calculateScale(options, metrics.widthPixels, metrics.heightPixels);
options.inJustDecodeBounds = false;
return BitmapFactory.decodeResource(getResources(), id, options);
}
private int calculateScale(BitmapFactory.Options options, int reqWidth, int reqHeight){
final int rawHeight = options.outHeight;
final int rawWidth = options.outWidth;
int inSampleSize = 1;
if (rawHeight > reqHeight || rawWidth > reqWidth) {
// Calculate ratios of height and width to requested height and width
final int heightRatio = Math.round((float) rawHeight/(float) reqHeight);
final int widthRatio = Math.round((float) rawWidth/(float) reqWidth);
// Choose the smallest ratio as inSampleSize value, this will guarantee
// a final image with both dimensions larger than or equal to the
// requested height and width.
inSampleSize = heightRatio < widthRatio ? heightRatio : widthRatio;
}
return inSampleSize;
}
}
您可以立即,我使用一些硬編碼值看到屏幕上的定位。你能給我一些關於如何編碼的建議,以便它在每個屏幕上顯示(特別是中,高尺寸)。因爲它應該意味着不會模糊撕裂空白空間等等。如果您需要更多信息,請在評論中告訴我,非常感謝!
有沒有什麼辦法可以避免創建這些幻數(寬度*)等等? – Matsura 2014-08-30 13:37:17
魔法? :)如果您使用視圖而不是將'Drawable'繪製爲'Bitmap',則可以使用'LayoutParams'來設置相對於它們自己的視圖位置。 [Here](http://stackoverflow.com/questions/4638832/how-to-programmatically-set-the-layout-align-parent-right-attribute-of-a-button) – 2014-08-30 13:46:13
http://stackoverflow.com/questions/25507968/android-user-interface-using-photoshop-design這就是我想要創建的。是否可以使用佈局參數? – Matsura 2014-08-30 13:54:20