关于实现微信聊天气泡里显示图片

mykoss 2015-05-20 03:26:28

这是微信的效果,气泡中的图片没有边距




这是我的效果,背景气泡是用.9.png图片组成的一个selector,气泡中的图片有边距 如何才能像微信那样没有边矩呢?
...全文
1020 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
qq_35646648 2016-07-19
  • 打赏
  • 举报
回复
图片的容易搞,小视频怎么弄啊?有人搞过吗?
qq_31580947 2016-01-25
  • 打赏
  • 举报
回复
引用 3 楼 assky124 的回复:
可以用Bitmap画刷填充Path来实现


/**
 * Created by Coder.Yan on 2015/5/21.
 */
@SuppressWarnings("deprecation")
public class XORView extends View {
    Paint paint;
    Path path;
    BitmapShader brush;
    public XORView(Context context, AttributeSet attrs) {
        super(context, attrs);
        paint = new Paint();
        path = new Path();
        BitmapDrawable drawable = (BitmapDrawable)getResources().getDrawable(R.drawable.ic_texture);
        brush = new BitmapShader(drawable.getBitmap(), Shader.TileMode.REPEAT, Shader.TileMode.REPEAT);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        canvas.save();
        paint.setStyle(Paint.Style.FILL);
        //paint.setColor(Color.GREEN);
        paint.setShader(brush);
        canvas.drawPath(path, paint);
        paint.reset();
        paint.setStyle(Paint.Style.STROKE);
        canvas.drawPath(path, paint);
        canvas.restore();
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
        path.reset();
        int w = getWidth();
        int h = getHeight();
        path.moveTo(0,10);
        path.arcTo(new RectF(0,0,20,20),180,90);
        path.lineTo(w - 30,0);
        path.arcTo(new RectF(w - 40, 0, w - 20, 20), -90, 90);
        path.lineTo(w-20,h/2 -10);
        path.lineTo(w,h/2);
        path.lineTo(w-20,h/2 +10);
        path.lineTo(w-20,h - 10);
        path.arcTo(new RectF(w-40, h-20,w-20,h-1),0,90);
        path.lineTo(10,h-1);
        path.arcTo(new RectF(0,h-20,20,h-1),90,90);
        path.close();
    }
}

效果图
这个怎么用啊
mykoss 2015-05-21
  • 打赏
  • 举报
回复
顶,求大神求大神
assky124 2015-05-21
  • 打赏
  • 举报
回复
可以用Bitmap画刷填充Path来实现


/**
* Created by Coder.Yan on 2015/5/21.
*/
@SuppressWarnings("deprecation")
public class XORView extends View {
Paint paint;
Path path;
BitmapShader brush;
public XORView(Context context, AttributeSet attrs) {
super(context, attrs);
paint = new Paint();
path = new Path();
BitmapDrawable drawable = (BitmapDrawable)getResources().getDrawable(R.drawable.ic_texture);
brush = new BitmapShader(drawable.getBitmap(), Shader.TileMode.REPEAT, Shader.TileMode.REPEAT);
}

@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
canvas.save();
paint.setStyle(Paint.Style.FILL);
//paint.setColor(Color.GREEN);
paint.setShader(brush);
canvas.drawPath(path, paint);
paint.reset();
paint.setStyle(Paint.Style.STROKE);
canvas.drawPath(path, paint);
canvas.restore();
}

@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
path.reset();
int w = getWidth();
int h = getHeight();
path.moveTo(0,10);
path.arcTo(new RectF(0,0,20,20),180,90);
path.lineTo(w - 30,0);
path.arcTo(new RectF(w - 40, 0, w - 20, 20), -90, 90);
path.lineTo(w-20,h/2 -10);
path.lineTo(w,h/2);
path.lineTo(w-20,h/2 +10);
path.lineTo(w-20,h - 10);
path.arcTo(new RectF(w-40, h-20,w-20,h-1),0,90);
path.lineTo(10,h-1);
path.arcTo(new RectF(0,h-20,20,h-1),90,90);
path.close();
}
}


效果图
  • 打赏
  • 举报
回复
需自定义控件 测试发贴权限

80,352

社区成员

发帖
与我相关
我的任务
社区描述
移动平台 Android
androidandroid-studioandroidx 技术论坛(原bbs)
社区管理员
  • Android
  • yechaoa
  • 失落夏天
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧