Android 9.0 三方app whatsapp 拍照预览模糊

本文详细记录了解决Android9.0系统中WhatsApp应用拍照预览分辨率过低的问题过程。通过在framework层修改特定APP包名对应的预览尺寸,成功提升了预览画质,同时保持了图片输出质量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

之前在进行项目开发时,有碰到 Android 9.0 三方app whatsapp 拍照预览分辨率过低 现象,但是拍照出来的照片是清晰的, 查看log发现priview-size过低导致预览模糊,而picture-size则是正常的1080p.

问题解决:尝试过在 camxtitian7xcontext.cpp中删除所用的preview-size, 然后发现其还是调用了其他也较低的size,所以问题解决方案是在framework层获取whatsapp等其他app的包名,给它们返回几组固定的size,

grep "connect call"发现wahtsapp的包名为 “com.whatsapp”,使用的是camera api2 – hal3框架,所以需要在
framework/base/core/java/android/hardware/camera2/params/StreamConfigurationMap.java 文件中修改,追溯流程发现其是在如下函数中获取所支持的size ,所以做了如下修改,之后此问题fix,希望有所帮助.

添加包名:
	+import android.util.Log;
	+import android.app.ActivityThread;

public <T> Size[] getOutputSizes(Class<T> klass) {
    if (isOutputSupportedFor(klass) == false) {
        return null;
    }
    String packageName = ActivityThread.currentOpPackageName();
    Size[] sizes =getInternalFormatSizes(HAL_PIXEL_FORMAT_IMPLEMENTATION_DEFINED,
            HAL_DATASPACE_UNKNOWN,/*output*/true, /*highRes*/false);
	
	if(packageName != null && (packageName.equals("com.whatsapp")))
	{
		Size size1 = new Size(4000,3000);
		Size size2 = new Size(4000,2250);
		Size size3 = new Size(1920,1440);
		Size size4 = new Size(1920,1080);
		Size size5 = new Size(1280,720);
		Size[] whatsapp_size = {size1,size2,size3,size4,size5};
		
		return whatsapp_size;
	}
	return sizes;
}
### 使用 WhatsApp API 进行应用开发 #### 准备工作 为了成功利用WhatsApp API进行应用开发,开发者需先理解所选API的具体特性及其适用场景。对于企业级解决方案而言,通常会选择使用WhatsApp Business APIWhatsApp Cloud API[^2]。 #### 开发环境搭建 确保拥有稳定的网络环境至关重要,因为这直接影响到API请求的成功率和响应时间。建议参考官方文档来配置必要的代理服务或其他中间件以优化网络性能[^1]。 #### 应用程序创建 无论是选择哪种类型的API接口,在正式接入前都需要完成一系列初始化设置: - 注册成为开发者并获取相应权限; - 创建项目并通过认证流程获得访问令牌; - 配置Webhook用于接收来自WhatsApp的消息通知; ```json { "webhooks": { "url": "https://yourdomain.com/webhook", "verify_token": "YOUR_VERIFY_TOKEN" } } ``` #### 发送消息示例 下面是一个简单的Python脚本例子,展示了如何向指定联系人发送文本消息: ```python import requests def send_message(phone_number, message_text): url = &#39;https://graph.facebook.com/v13.0/WHATSAPP_API_PHONE_NUMBER_ID/messages&#39; headers = {&#39;Authorization&#39;: f&#39;Bearer YOUR_ACCESS_TOKEN&#39;} payload = { "messaging_product": "whatsapp", "recipient_type": "individual", "to": phone_number, "type": "text", "text": {"body": message_text} } response = requests.post(url=url, json=payload, headers=headers) if __name__ == &#39;__main__&#39;: send_message(&#39;123456789&#39;, &#39;Hello from your app!&#39;) ``` 此代码片段假设读者已经获得了有效的`ACCESS_TOKEN`以及正确的`PHONE_NUMBER_ID`参数值,并将其替换为实际使用的凭证信息。 #### 数据安全与隐私保护 在整个过程中始终重视数据的安全性和用户的隐私权。遵循GDPR等相关法律法规的要求,妥善保管用户个人信息,避免泄露风险。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值