【问题标题】:Image not cropping图像未裁剪
【发布时间】:2013-01-06 17:28:59
【问题描述】:

我将background 图像设置为LinearLayout,如下所示:

1.back_xml:

<?xml version="1.0" encoding="UTF-8"?>
  <layer-list xmlns:android="http://schemas.android.com/apk/res/android">  
       <item android:drawable="@drawable/back" >
        </item>
    <item>
        <shape>
            <solid/>
            <stroke android:width="1dip" android:color="#225786" />
            <corners android:radius="10dip"/>
            <padding android:left="0dip" android:top="0dip" android:right="0dip" android:bottom="0dip" />
        </shape>
    </item> 

2。 tile.xml

    <bitmap xmlns:android="http://schemas.android.com/apk/res/android"
        android:src="@drawable/pie_chart_background"
        android:tileMode="repeat">
    </bitmap>

现在我将 back.xml 设置为 backgroundLinearLayout 它工作正常。

我需要一个带有圆角image和一个边框。但我只有圆角边框而不是图像我的代码中的问题是我遗漏了什么吗?

这是我的图像的外观:

【问题讨论】:

标签: android image bitmap crop


【解决方案1】:

解决方案 1

  1. 为边框创建一个 9-patch 图像。图片的中间部分应该是透明的。

  2. 使用 RelativeLayout 作为父级,并将您的图像 LinearLayout 放在底部。将边框 9-patch 设置为另一个线性布局的背景,并将其放在图像 LinearLayout 的顶部。然后它会覆盖角落,你会得到预期的结果。

解决方案 2

public static Bitmap getRoundedCornerBitmap(Bitmap bitmap) {
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());
final RectF rectF = new RectF(rect);
final float roundPx = 12;

paint.setAntiAlias(true);
canvas.drawARGB(0, 0, 0, 0);
paint.setColor(color);
canvas.drawRoundRect(rectF, roundPx, roundPx, paint);

paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
canvas.drawBitmap(bitmap, rect, rect, paint);

return output;

}

【讨论】:

  • 你能帮帮我吗
  • 我已经更新了我的答案。您甚至可以使用第二种解决方案
  • 是的,我已经尝试过,但问题在于为其添加边框,并且在横向模式下看起来不太好以及如何添加平铺模式重复
【解决方案2】:

在您的问题上花费了数小时的时间后,我终于实现了,希望现在它会给您带来您想要的结果,请通过下面的代码告诉我它是否有效?

将适当的参数传递给下面的函数以获得带有您想要的颜色边框的圆角。

public static Bitmap getRoundedCornerImage(Bitmap bitmap, int cornerDips, int borderDips, Context context) {
        Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(),
                Bitmap.Config.ARGB_8888);
        Canvas canvas = new Canvas(output);

        final int borderSizePx = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, (float) borderDips,
                context.getResources().getDisplayMetrics());
        final int cornerSizePx = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, (float) cornerDips,
                context.getResources().getDisplayMetrics());
        final Paint paint = new Paint();
        final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight());
        final RectF rectF = new RectF(rect);


        paint.setAntiAlias(true);
        paint.setColor(0xFFFFFFFF);
        paint.setStyle(Paint.Style.FILL);
        canvas.drawARGB(0, 0, 0, 0);
        canvas.drawRoundRect(rectF, cornerSizePx, cornerSizePx, paint);


        paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
        canvas.drawBitmap(bitmap, rect, rect, paint);


        paint.setColor((Color.RED)); // you can change color of your border here, to other color
        paint.setStyle(Paint.Style.STROKE);
        paint.setStrokeWidth((float) borderSizePx);
        canvas.drawRoundRect(rectF, cornerSizePx, cornerSizePx, paint);

        return output;
    }

main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center"
    tools:context=".MainActivity" >

    <ImageView
        android:id="@+id/image"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"

      />

</RelativeLayout>

OnCreate

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        ImageView rl=(ImageView)findViewById(R.id.image);


    Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.testing); // your desire drawable image.
    rl.setImageBitmap(getRoundedCornerImage(bitmap, 10, 10, this));

    }

原图

输出

以下链接帮助我实现目标:

Border over a bitmap with rounded corners in Android

Creating ImageView with round corners

How to make an ImageView to have rounded corners

How to set paint.setColor(int color)

【讨论】:

  • 除了上面的代码,对于你的情况@Goofy,你可以有一个最外面的RelativeLayout,里面有LinearLayout和ImageView。设置 imageLayout 参数:android:layout_alignTop="@+id/frame1" android:layout_alignBottom="@+id/frame1" 和 LinearLayout 的背景为透明。这样,用户会感觉好像线性布局设置了背景图像!!!
【解决方案3】:

我认为你应该这样做。

<layer-list xmlns:android="http://schemas.android.com/apk/res/android">  
<item>
    <shape>
        <solid android:color="@color/back" />
        <stroke android:width="1dip" android:color="#225786" />
        <corners android:radius="10dip"/>
        <padding android:left="0dip" android:top="0dip" android:right="0dip" android:bottom="0dip" />
    </shape>
</item> 

如果背景不是颜色而是位图,你应该遵循这个漂亮的指南 http://www.curious-creature.org/2012/12/11/android-recipe-1-image-with-rounded-corners/

【讨论】:

    【解决方案4】:

    将您的形状与圆角图像结合使用。

    您可以使用 AndroidQuery 加载带有圆角的图像。 见http://code.google.com/p/android-query/wiki/ImageLoading#Rounded_Corner

    String url ="http://www.vikispot.com/z/images/vikispot/android-w.png";
    ImageOptions options = new ImageOptions(); 
    options.round = 15;
    aq.id(R.id.image).image(url, options);
    

    【讨论】:

      【解决方案5】:

      Raj 发布的另一种替代方法是在角落使用具有透明度的背景图片。

      由于您的背景很简单,最好的解决方案是使用 9-patch,这是大多数背景图像的 Android 原生解决方案:http://developer.android.com/guide/topics/graphics/2d-graphics.html#nine-patch,其风格类似于某些网站背景的样式绘制。

      Android 也有它自己的 9-patch 创建器与 sdk 捆绑在一起:http://developer.android.com/tools/help/draw9patch.html,因此编辑您自己的 png 文件非常容易,然后将 9-patch 应用到布局。 9-patches 的优势在于它们还可以为您处理 UI 大小的调整,这意味着您在不同屏幕上使用应用时不会遇到太多问题

      【讨论】:

        【解决方案6】:

        试试你的 back.xml 类似这样的东西,而不是给出一个矩形背景图像。

        <?xml version="1.0" encoding="UTF-8"?>
        <layer-list xmlns:android="http://schemas.android.com/apk/res/android">  
           <item android:drawable="#ff00ff >
            </item>
         <item>
            <shape android:shape="rectangle" >
                <solid/>
                <stroke android:width="1dip" android:color="#225786" />
                <corners android:radius="10dip"/>
                <padding android:left="0dip" android:top="0dip" android:right="0dip" android:bottom="0dip" />
            </shape>
          </item> 
        

        【讨论】:

        • 您可以获得该图像的六色并提供。否则,您可以务实地裁剪图像并将其设置为背景。否则,您将创建一个带有圆角的图像并将其作为背景作为您的捐赠。
        猜你喜欢
        • 1970-01-01
        • 2022-08-04
        • 2017-05-22
        • 1970-01-01
        • 1970-01-01
        • 2022-01-23
        • 2023-04-02
        • 1970-01-01
        相关资源
        最近更新 更多