Ritaglia l'image quadrata in cerchio – Programmaticamente

stavo cercando un giorno dopo e non avevo successo.

ottengo l'image dalla API e lo scaricherò in un file bitmap utilizzando il seguente codice.

  • Impostazione di Theme.Light di Android per la window di dialogo di avviso
  • La perdita di memory attraverso IClipboardDataPasteEventImpl
  • Da Android a node.js comunicazione
  • Impostazioni di emulatore Samsung Galaxy s3
  • Android GridView con separatore
  • Cambiare il tema in base alla versione Android
  • private Bitmap DownloadImage(String URL) { Bitmap bitmap = null; InputStream in = null; try { in = OpenHttpConnection(URL); bitmap = BitmapFactory.decodeStream(in); in.close(); } catch (IOException e1) { e1.printStackTrace(); } return bitmap; } private InputStream OpenHttpConnection(String urlString) throws IOException { InputStream in = null; int response = -1; URL url = new URL(urlString); URLConnection conn = url.openConnection(); if (!(conn instanceof HttpURLConnection)) throw new IOException("Not an HTTP connection"); try { HttpURLConnection httpConn = (HttpURLConnection) conn; httpConn.setAllowUserInteraction(false); httpConn.setInstanceFollowRedirects(true); httpConn.setRequestMethod("GET"); httpConn.connect(); response = httpConn.getResponseCode(); if (response == HttpURLConnection.HTTP_OK) { in = httpConn.getInputStream(); } } catch (Exception ex) { throw new IOException("Error connecting"); } return in; } 

    E ho l'image come un quadrato e voglio tagliare i quattro angoli e farlo all'image circolare. C'è un ansible modo per raggiungere?

    Tutte le risposte correlate sono accolte. Grazie in anticipo .

  • Come call notifyDataSetChanged () da un generico adattatore
  • le schermate dello schizzo dello android per i display di ldpi, mdpi, hdpi, xhdpi? - es .: 1024x768 pixel per ldpi
  • Ridurre la dimensione di Bitmap ad alcuni pixel specificati in Android
  • Come aggiornare un widget di app in mezzanotte?
  • Android - fai una forma freccia con xml
  • Android Sinistra, Centrale e Allineamento Destra
  • 5 Solutions collect form web for “Ritaglia l'image quadrata in cerchio – Programmaticamente”

     public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); DrawingView dv = new DrawingView(this); setContentView(dv); } class DrawingView extends View { Bitmap bitmap; public DrawingView(Context context) { super(context); bitmap = BitmapFactory.decodeResource(context.getResources(), R.drawable.glossy_overlay); } @Override public void onDraw(Canvas canvas) { Paint paint = new Paint(); // paint.setColor(Color.CYAN); canvas.drawBitmap(getclip(), 30, 20, paint); } public Bitmap getclip() { Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(), Config.ARGB_8888); Canvas canvas = new Canvas(output); final int color = 0xff424242; final Paint paint = new Paint(); final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight()); paint.setAntiAlias(true); canvas.drawARGB(0, 0, 0, 0); // paint.setColor(color); canvas.drawCircle(bitmap.getWidth() / 2, bitmap.getHeight() / 2, bitmap.getWidth() / 2, paint); paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN)); canvas.drawBitmap(bitmap, rect, rect, paint); return output; } } } 

    utilizzare il colpo di function per disegnare il cerchio su bitmap e quindi impostare la bitmap circondata in immagini

     public static Bitmap getclip(Bitmap bitmap) { Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(), Config.ARGB_8888); Canvas canvas = new Canvas(output); final Paint paint = new Paint(); final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight()); paint.setAntiAlias(true); canvas.drawARGB(0, 0, 0, 0); canvas.drawCircle(bitmap.getWidth() / 2, bitmap.getHeight() / 2, bitmap.getWidth() / 2, paint); paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN)); canvas.drawBitmap(bitmap, rect, rect, paint); return output; } 

    Una volta che il bitmap viene recuperato, RoundedBitmapDrawableFactory può essere utilizzato per generare un RoundedBitmapDrawable dalla libreria di supporto v4 . Quel Drawable può quindi essere applicato ad un ImageView o direttamente disegnato su una Canvas .

     // Create the RoundedBitmapDrawable. RoundedBitmapDrawable roundDrawable = RoundedBitmapDrawableFactory.create(getResources(), bitmap); roundDrawable.setCircular(true); // Apply it to an ImageView. ImageView imageView = (ImageView)findViewById(R.id.imageView); imageView.setImageDrawable(roundDrawable); // Alternatively, draw it to an canvas (eg in onDraw where a Canvas is available). // setBounds since there's no View handling size and positioning. roundDrawable.setBounds(left, top, right, bottom); roundDrawable.draw(canvas); 

    Roman Nurik propone un uso molto diretto degli shader per fare cose del genere, con un disegno personalizzato.

    Cambierò un po 'il codice per fare un'image ovale e testarmi. L'effetto e le performance sono veramente buoni:

     public class StreamDrawable extends Drawable { private static final boolean USE_VIGNETTE = true; private final RectF mRect = new RectF(); private final BitmapShader mBitmapShader; private final Paint mPaint; private final int mMargin; public StreamDrawable(Bitmap bitmap, int margin) { mBitmapShader = new BitmapShader(bitmap, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP); mPaint = new Paint(); mPaint.setAntiAlias(true); mPaint.setShader(mBitmapShader); mMargin = margin; } @Override protected void onBoundsChange(Rect bounds) { super.onBoundsChange(bounds); mRect.set(mMargin, mMargin, bounds.width() - mMargin, bounds.height() - mMargin); if (USE_VIGNETTE) { RadialGradient vignette = new RadialGradient( mRect.centerX(), mRect.centerY() * 1.0f / 0.7f, mRect.centerX() * 1.3f, new int[] { 0, 0, 0x7f000000 }, new float[] { 0.0f, 0.7f, 1.0f }, Shader.TileMode.CLAMP); Matrix oval = new Matrix(); oval.setScale(1.0f, 0.7f); vignette.setLocalMatrix(oval); mPaint.setShader( new ComposeShader(mBitmapShader, vignette, PorterDuff.Mode.SRC_OVER)); } } @Override public void draw(Canvas canvas) { canvas.drawOval(mRect, mPaint); } @Override public int getOpacity() { return PixelFormat.TRANSLUCENT; } @Override public void setAlpha(int alpha) { mPaint.setAlpha(alpha); } @Override public void setColorFilter(ColorFilter cf) { mPaint.setColorFilter(cf); } } 

    Questo può essere fatto semplicemente in xml, per favore vedi la mia risposta qui: https://stackoverflow.com/a/18287979/665930

     <RelativeLayout android:id="@+id/icon_layout" android:layout_width="@dimen/icon_mask" android:layout_height="@dimen/icon_mask" android:layout_alignParentLeft="true" android:layout_alignParentTop="true" > <ImageView android:id="@+id/icon" android:layout_width="@dimen/icon" android:layout_height="@dimen/icon" android:layout_centerInParent="true" android:scaleType="fitXY" > </ImageView> <ImageView android:id="@+id/icon_mask" android:layout_width="@dimen/icon_mask" android:layout_height="@dimen/icon_mask" android:layout_centerInParent="true" android:background="@drawable/circle" android:scaleType="fitXY" > </ImageView> </RelativeLayout> <?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="oval" > <gradient android:startColor="#00FFFFFF" android:endColor="#00FFFFFF" android:angle="270"/> <stroke android:width="10dp" android:color="#FFAAAAAA"/> 
    L'Android è un fan Android di Google, tutto su telefoni Android, Android Wear, Android Dev e applicazioni Android Games e così via.