auto import from //branches/cupcake/...@127436
This commit is contained in:
@@ -1,4 +1,18 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!-- Copyright (C) 2009 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<string name="appTitle">"Záloha"</string>
|
<string name="appTitle">"Záloha"</string>
|
||||||
|
|||||||
@@ -1,4 +1,18 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!-- Copyright (C) 2009 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<string name="appTitle">"Fallback"</string>
|
<string name="appTitle">"Fallback"</string>
|
||||||
|
|||||||
@@ -1,4 +1,18 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!-- Copyright (C) 2009 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<string name="appTitle">"Fallback"</string>
|
<string name="appTitle">"Fallback"</string>
|
||||||
|
|||||||
@@ -1,4 +1,18 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!-- Copyright (C) 2009 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<string name="appTitle">"Application de secours"</string>
|
<string name="appTitle">"Application de secours"</string>
|
||||||
|
|||||||
@@ -1,4 +1,18 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!-- Copyright (C) 2009 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<string name="appTitle">"Fallback"</string>
|
<string name="appTitle">"Fallback"</string>
|
||||||
|
|||||||
@@ -1,4 +1,18 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!-- Copyright (C) 2009 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<string name="appTitle">"Fallback"</string>
|
<string name="appTitle">"Fallback"</string>
|
||||||
|
|||||||
@@ -1,4 +1,18 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!-- Copyright (C) 2009 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<string name="appTitle">"Reserve"</string>
|
<string name="appTitle">"Reserve"</string>
|
||||||
|
|||||||
@@ -1,4 +1,18 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!-- Copyright (C) 2009 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<string name="appTitle">"Wycofanie"</string>
|
<string name="appTitle">"Wycofanie"</string>
|
||||||
|
|||||||
@@ -1,4 +1,18 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!-- Copyright (C) 2009 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<string name="appTitle">"Fallback"</string>
|
<string name="appTitle">"Fallback"</string>
|
||||||
|
|||||||
@@ -1,4 +1,18 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!-- Copyright (C) 2009 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<string name="appTitle">"Fallback"</string>
|
<string name="appTitle">"Fallback"</string>
|
||||||
|
|||||||
@@ -1,4 +1,18 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!-- Copyright (C) 2009 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
<resources xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2">
|
||||||
<string name="appTitle">"備用"</string>
|
<string name="appTitle">"備用"</string>
|
||||||
|
|||||||
Binary file not shown.
Binary file not shown.
@@ -1582,6 +1582,13 @@
|
|||||||
</intent-filter>
|
</intent-filter>
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
|
<activity android:name=".graphics.BitmapPixels" android:label="Graphics/BitmapPixels">
|
||||||
|
<intent-filter>
|
||||||
|
<action android:name="android.intent.action.MAIN" />
|
||||||
|
<category android:name="android.intent.category.SAMPLE_CODE" />
|
||||||
|
</intent-filter>
|
||||||
|
</activity>
|
||||||
|
|
||||||
<activity android:name=".graphics.Xfermodes" android:label="Graphics/Xfermodes">
|
<activity android:name=".graphics.Xfermodes" android:label="Graphics/Xfermodes">
|
||||||
<intent-filter>
|
<intent-filter>
|
||||||
<action android:name="android.intent.action.MAIN" />
|
<action android:name="android.intent.action.MAIN" />
|
||||||
|
|||||||
@@ -0,0 +1,168 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2007 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.example.android.apis.graphics;
|
||||||
|
|
||||||
|
import com.example.android.apis.R;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.graphics.*;
|
||||||
|
import android.graphics.drawable.*;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.KeyEvent;
|
||||||
|
import android.view.*;
|
||||||
|
|
||||||
|
import java.nio.IntBuffer;
|
||||||
|
import java.nio.ShortBuffer;
|
||||||
|
|
||||||
|
public class BitmapPixels extends GraphicsActivity {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(new SampleView(this));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class SampleView extends View {
|
||||||
|
private Bitmap mBitmap1;
|
||||||
|
private Bitmap mBitmap2;
|
||||||
|
private Bitmap mBitmap3;
|
||||||
|
private Bitmap mBitmap4;
|
||||||
|
|
||||||
|
// access the red component from a premultiplied color
|
||||||
|
private static int getR32(int c) { return (c >> 0) & 0xFF; }
|
||||||
|
// access the red component from a premultiplied color
|
||||||
|
private static int getG32(int c) { return (c >> 8) & 0xFF; }
|
||||||
|
// access the red component from a premultiplied color
|
||||||
|
private static int getB32(int c) { return (c >> 16) & 0xFF; }
|
||||||
|
// access the red component from a premultiplied color
|
||||||
|
private static int getA32(int c) { return (c >> 24) & 0xFF; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This takes components that are already in premultiplied form, and
|
||||||
|
* packs them into an int in the correct device order.
|
||||||
|
*/
|
||||||
|
private static int pack8888(int r, int g, int b, int a) {
|
||||||
|
return (r << 0) | ( g << 8) | (b << 16) | (a << 24);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static short pack565(int r, int g, int b) {
|
||||||
|
return (short)((r << 11) | ( g << 5) | (b << 0));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static short pack4444(int r, int g, int b, int a) {
|
||||||
|
return (short)((a << 0) | ( b << 4) | (g << 8) | (r << 12));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static int mul255(int c, int a) {
|
||||||
|
int prod = c * a + 128;
|
||||||
|
return (prod + (prod >> 8)) >> 8;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Turn a color int into a premultiplied device color
|
||||||
|
*/
|
||||||
|
private static int premultiplyColor(int c) {
|
||||||
|
int r = Color.red(c);
|
||||||
|
int g = Color.green(c);
|
||||||
|
int b = Color.blue(c);
|
||||||
|
int a = Color.alpha(c);
|
||||||
|
// now apply the alpha to r, g, b
|
||||||
|
r = mul255(r, a);
|
||||||
|
g = mul255(g, a);
|
||||||
|
b = mul255(b, a);
|
||||||
|
// now pack it in the correct order
|
||||||
|
return pack8888(r, g, b, a);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void makeRamp(int from, int to, int n,
|
||||||
|
int[] ramp8888, short[] ramp565,
|
||||||
|
short[] ramp4444) {
|
||||||
|
int r = getR32(from) << 23;
|
||||||
|
int g = getG32(from) << 23;
|
||||||
|
int b = getB32(from) << 23;
|
||||||
|
int a = getA32(from) << 23;
|
||||||
|
// now compute our step amounts per componenet (biased by 23 bits)
|
||||||
|
int dr = ((getR32(to) << 23) - r) / (n - 1);
|
||||||
|
int dg = ((getG32(to) << 23) - g) / (n - 1);
|
||||||
|
int db = ((getB32(to) << 23) - b) / (n - 1);
|
||||||
|
int da = ((getA32(to) << 23) - a) / (n - 1);
|
||||||
|
|
||||||
|
for (int i = 0; i < n; i++) {
|
||||||
|
ramp8888[i] = pack8888(r >> 23, g >> 23, b >> 23, a >> 23);
|
||||||
|
ramp565[i] = pack565(r >> (23+3), g >> (23+2), b >> (23+3));
|
||||||
|
ramp4444[i] = pack4444(r >> (23+4), g >> (23+4), b >> (23+4),
|
||||||
|
a >> (23+4));
|
||||||
|
r += dr;
|
||||||
|
g += dg;
|
||||||
|
b += db;
|
||||||
|
a += da;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static IntBuffer makeBuffer(int[] src, int n) {
|
||||||
|
IntBuffer dst = IntBuffer.allocate(n*n);
|
||||||
|
for (int i = 0; i < n; i++) {
|
||||||
|
dst.put(src);
|
||||||
|
}
|
||||||
|
dst.rewind();
|
||||||
|
return dst;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static ShortBuffer makeBuffer(short[] src, int n) {
|
||||||
|
ShortBuffer dst = ShortBuffer.allocate(n*n);
|
||||||
|
for (int i = 0; i < n; i++) {
|
||||||
|
dst.put(src);
|
||||||
|
}
|
||||||
|
dst.rewind();
|
||||||
|
return dst;
|
||||||
|
}
|
||||||
|
|
||||||
|
public SampleView(Context context) {
|
||||||
|
super(context);
|
||||||
|
setFocusable(true);
|
||||||
|
|
||||||
|
final int N = 100;
|
||||||
|
int[] data8888 = new int[N];
|
||||||
|
short[] data565 = new short[N];
|
||||||
|
short[] data4444 = new short[N];
|
||||||
|
|
||||||
|
makeRamp(premultiplyColor(Color.RED), premultiplyColor(Color.GREEN),
|
||||||
|
N, data8888, data565, data4444);
|
||||||
|
|
||||||
|
mBitmap1 = Bitmap.createBitmap(N, N, Bitmap.Config.ARGB_8888);
|
||||||
|
mBitmap2 = Bitmap.createBitmap(N, N, Bitmap.Config.RGB_565);
|
||||||
|
mBitmap3 = Bitmap.createBitmap(N, N, Bitmap.Config.ARGB_4444);
|
||||||
|
|
||||||
|
mBitmap1.copyPixelsFromBuffer(makeBuffer(data8888, N));
|
||||||
|
mBitmap2.copyPixelsFromBuffer(makeBuffer(data565, N));
|
||||||
|
mBitmap3.copyPixelsFromBuffer(makeBuffer(data4444, N));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override protected void onDraw(Canvas canvas) {
|
||||||
|
canvas.drawColor(0xFFCCCCCC);
|
||||||
|
|
||||||
|
int y = 10;
|
||||||
|
canvas.drawBitmap(mBitmap1, 10, y, null);
|
||||||
|
y += mBitmap1.getHeight() + 10;
|
||||||
|
canvas.drawBitmap(mBitmap2, 10, y, null);
|
||||||
|
y += mBitmap2.getHeight() + 10;
|
||||||
|
canvas.drawBitmap(mBitmap3, 10, y, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@@ -68,6 +68,8 @@ public class SoftKeyboard extends InputMethodService
|
|||||||
private Keyboard mSymbolsShiftedKeyboard;
|
private Keyboard mSymbolsShiftedKeyboard;
|
||||||
private Keyboard mQwertyKeyboard;
|
private Keyboard mQwertyKeyboard;
|
||||||
|
|
||||||
|
private Keyboard mCurKeyboard;
|
||||||
|
|
||||||
private String mWordSeparators;
|
private String mWordSeparators;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -132,8 +134,8 @@ public class SoftKeyboard extends InputMethodService
|
|||||||
* bound to the client, and are now receiving all of the detailed information
|
* bound to the client, and are now receiving all of the detailed information
|
||||||
* about the target of our edits.
|
* about the target of our edits.
|
||||||
*/
|
*/
|
||||||
@Override public void onStartInputView(EditorInfo attribute, boolean restarting) {
|
@Override public void onStartInput(EditorInfo attribute, boolean restarting) {
|
||||||
super.onStartInputView(attribute, restarting);
|
super.onStartInput(attribute, restarting);
|
||||||
|
|
||||||
// Reset our state. We want to do this even if restarting, because
|
// Reset our state. We want to do this even if restarting, because
|
||||||
// the underlying state of the text editor could have changed in any way.
|
// the underlying state of the text editor could have changed in any way.
|
||||||
@@ -148,7 +150,6 @@ public class SoftKeyboard extends InputMethodService
|
|||||||
mPredictionOn = false;
|
mPredictionOn = false;
|
||||||
mCompletionOn = false;
|
mCompletionOn = false;
|
||||||
mCompletions = null;
|
mCompletions = null;
|
||||||
Keyboard keyboard;
|
|
||||||
|
|
||||||
// We are now going to initialize our state based on the type of
|
// We are now going to initialize our state based on the type of
|
||||||
// text being edited.
|
// text being edited.
|
||||||
@@ -157,13 +158,13 @@ public class SoftKeyboard extends InputMethodService
|
|||||||
case EditorInfo.TYPE_CLASS_DATETIME:
|
case EditorInfo.TYPE_CLASS_DATETIME:
|
||||||
// Numbers and dates default to the symbols keyboard, with
|
// Numbers and dates default to the symbols keyboard, with
|
||||||
// no extra features.
|
// no extra features.
|
||||||
keyboard = mSymbolsKeyboard;
|
mCurKeyboard = mSymbolsKeyboard;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EditorInfo.TYPE_CLASS_PHONE:
|
case EditorInfo.TYPE_CLASS_PHONE:
|
||||||
// Phones will also default to the symbols keyboard, though
|
// Phones will also default to the symbols keyboard, though
|
||||||
// often you will want to have a dedicated phone keyboard.
|
// often you will want to have a dedicated phone keyboard.
|
||||||
keyboard = mSymbolsKeyboard;
|
mCurKeyboard = mSymbolsKeyboard;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EditorInfo.TYPE_CLASS_TEXT:
|
case EditorInfo.TYPE_CLASS_TEXT:
|
||||||
@@ -171,7 +172,7 @@ public class SoftKeyboard extends InputMethodService
|
|||||||
// normal alphabetic keyboard, and assume that we should
|
// normal alphabetic keyboard, and assume that we should
|
||||||
// be doing predictive text (showing candidates as the
|
// be doing predictive text (showing candidates as the
|
||||||
// user types).
|
// user types).
|
||||||
keyboard = mQwertyKeyboard;
|
mCurKeyboard = mQwertyKeyboard;
|
||||||
mPredictionOn = true;
|
mPredictionOn = true;
|
||||||
|
|
||||||
// We now look for a few special variations of text that will
|
// We now look for a few special variations of text that will
|
||||||
@@ -209,13 +210,7 @@ public class SoftKeyboard extends InputMethodService
|
|||||||
default:
|
default:
|
||||||
// For all unknown input types, default to the alphabetic
|
// For all unknown input types, default to the alphabetic
|
||||||
// keyboard with no special features.
|
// keyboard with no special features.
|
||||||
keyboard = mQwertyKeyboard;
|
mCurKeyboard = mQwertyKeyboard;
|
||||||
}
|
|
||||||
|
|
||||||
// Apply the selected keyboard to the input view.
|
|
||||||
if (mInputView != null) {
|
|
||||||
mInputView.setKeyboard(keyboard);
|
|
||||||
mInputView.closing();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -236,11 +231,19 @@ public class SoftKeyboard extends InputMethodService
|
|||||||
// its window.
|
// its window.
|
||||||
setCandidatesViewShown(false);
|
setCandidatesViewShown(false);
|
||||||
|
|
||||||
|
mCurKeyboard = mQwertyKeyboard;
|
||||||
if (mInputView != null) {
|
if (mInputView != null) {
|
||||||
mInputView.closing();
|
mInputView.closing();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override public void onStartInputView(EditorInfo attribute, boolean restarting) {
|
||||||
|
super.onStartInputView(attribute, restarting);
|
||||||
|
// Apply the selected keyboard to the input view.
|
||||||
|
mInputView.setKeyboard(mCurKeyboard);
|
||||||
|
mInputView.closing();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deal with the editor reporting movement of its cursor.
|
* Deal with the editor reporting movement of its cursor.
|
||||||
*/
|
*/
|
||||||
@@ -350,6 +353,10 @@ public class SoftKeyboard extends InputMethodService
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case KeyEvent.KEYCODE_ENTER:
|
||||||
|
// Let the underlying text editor always handle these.
|
||||||
|
return false;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
// For all other keys, if we want to do transformations on
|
// For all other keys, if we want to do transformations on
|
||||||
// text being entered with a hard keyboard, we need to process
|
// text being entered with a hard keyboard, we need to process
|
||||||
@@ -500,13 +507,13 @@ public class SoftKeyboard extends InputMethodService
|
|||||||
|
|
||||||
public void setSuggestions(List<String> suggestions, boolean completions,
|
public void setSuggestions(List<String> suggestions, boolean completions,
|
||||||
boolean typedWordValid) {
|
boolean typedWordValid) {
|
||||||
if (mCandidateView != null) {
|
|
||||||
mCandidateView.setSuggestions(suggestions, completions, typedWordValid);
|
|
||||||
if (suggestions != null && suggestions.size() > 0) {
|
if (suggestions != null && suggestions.size() > 0) {
|
||||||
setCandidatesViewShown(true);
|
setCandidatesViewShown(true);
|
||||||
} else if (isFullscreenMode()) {
|
} else if (isFullscreenMode()) {
|
||||||
setCandidatesViewShown(true);
|
setCandidatesViewShown(true);
|
||||||
}
|
}
|
||||||
|
if (mCandidateView != null) {
|
||||||
|
mCandidateView.setSuggestions(suggestions, completions, typedWordValid);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user