- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我无法加载所选图像。正在加载默认模板图像。我用帖子中的完整 fragment 代码编辑了它,您能指导我使用哪个参数上传到所选图像吗?
以下更新后的代码可以工作,但只能上传预定义的图像,我无法上传所选图像,我不知道该行上使用哪个参数
if (this.imageUri != imageUri && requestCode == IMAGE_PICK_CODE && resultCode == RESULT_OK) {
class ReportFragment : Fragment(), OnMapReadyCallback, GoogleMap.OnMapClickListener, GoogleMap.OnCameraIdleListener {
private var mMapView: MapView? = null
private var map: GoogleMap? = null
val CAMERA_PERMISSION_CODE = 0
val CAMERA_REQUEST_CODE = 10
lateinit var imageFilePath: String
private var imgThumb: ImageView? = null
private var spinner: Spinner? = null
private var currentLocation: LatLng? = null // TODO: get current location as static variable
private var midLatLng: LatLng? = null
private var lat: Double? = null
private var lng: Double? = null
private var objectValues: Array<String>? = null
private var imageUri: Uri? = null
private var pictureTaken: Boolean = false
private var progress: ProgressBar? = null
val PERMISSION_CODE_READ = 1001
val PERMISSION_CODE_WRITE = 1002
val IMAGE_PICK_CODE = 1000
private val database: FirebaseDatabase? = FirebaseDatabase.getInstance()
private val markersRef: DatabaseReference? = database!!.getReference("markers")
private val storage = FirebaseStorage.getInstance()
private val storageRef: StorageReference = storage.reference
private var imagesRef: StorageReference? = null
private val permissoes = arrayOf(Manifest.permission.READ_EXTERNAL_STORAGE)
inner class GenericFileProvider : FileProvider()
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?): View? {
ContextCompat.checkSelfPermission(this.context,
Manifest.permission.READ_EXTERNAL_STORAGE)
ContextCompat.checkSelfPermission(this.context,
Manifest.permission.WRITE_EXTERNAL_STORAGE)
Permissoes.validarPermissoes(permissoes, this.activity, 1)
// Inflate the layout for this fragment
val view = inflater.inflate(R.layout.fragment_report, container, false)
if (arguments != null && arguments.getDouble("lat") != null) {
this.lat = arguments.getDouble("lat")
this.lng = arguments.getDouble("lng")
}
this.objectValues = resources.getStringArray(R.array.object_values) // for dropdown
// TODO this.currentLocation = Utils.currentLocation
this.progress = view.findViewById(R.id.progressBar) as ProgressBar
// Needs to call MapsInitializer before doing any CameraUpdateFactory calls
try {
initMap(view, savedInstanceState)
} catch (e: GooglePlayServicesNotAvailableException) {
e.printStackTrace()
}
this.imgThumb = view.findViewById(R.id.takePictureThumbnail) as ImageButton
val camBtn = view.findViewById(R.id.takePictureBtn) as ImageButton
val createBtn = view.findViewById(R.id.createIssueBtn) as Button
camBtn.setOnClickListener{
pickImageFromGallery()
}
this.imgThumb!!.setOnClickListener{
takePicture()
}
this.spinner = view.findViewById<Spinner>(R.id.object_types_spinner)
// Create an ArrayAdapter using the string array and a default spinner layout
val adapter = ArrayAdapter.createFromResource(context, R.array.object_types, android.R.layout.simple_spinner_item)
// Specify the layout to use when the list of choices appears
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item)
this.spinner!!.adapter = adapter
createBtn.setOnClickListener{
createIssue(view)
}
return view
}
fun createIssue(view: View) {
this.progress!!.visibility = View.VISIBLE
val layout = view.findViewById<LinearLayout>(R.id.reportLinearLayout)
layout.alpha = 0.4f
val random = UUID.randomUUID().toString()
val imgUrl = "images/issue$random+.jpg"
val name = view.findViewById<EditText>(R.id.issueNameEditText).text.toString()
val desc = view.findViewById<EditText>(R.id.issueDescriptionEditText).text.toString()
val type = this.objectValues!![this.spinner!!.selectedItemPosition]
var issue = Issue(name, type, this.midLatLng!!.latitude, this.midLatLng!!.longitude, desc, imgUrl, null)
this.imagesRef = storageRef.child(imgUrl)
var uploadTask: UploadTask = this.imagesRef!!.putBytes(putImgToBytearray())
uploadTask.addOnSuccessListener { taskSnapshot ->
this.progress!!.visibility = View.GONE
Toast.makeText(context,"upload Done",Toast.LENGTH_LONG).show()
markersRef!!.child(random).setValue(issue)
goToDetailsView(issue)
}.addOnFailureListener {
this.progress!!.visibility = View.GONE
Toast.makeText(context,"upload failed",Toast.LENGTH_LONG).show()
}.addOnProgressListener {
var prog: Double = (100.0 * it.bytesTransferred )/ it.totalByteCount
Log.i("transfer", prog.toString())
//this.progress!!.setProgress(prog.toInt(), true)
}
}
private fun goToDetailsView(issue: Issue) {
val args = Bundle()
val detailsFragment = IssueDetailsFragment()
args.putDouble("lat", issue.lat)
args.putDouble("lng", issue.lng)
args.putString("description", issue.description)
args.putString("name", issue.name)
args.putString("type", issue.type)
args.putString("imgUrl", issue.imgUrl)
detailsFragment.arguments = args
val ft = fragmentManager.beginTransaction()
ft.replace(R.id.main_fragment_content, detailsFragment)
.setTransition(android.app.FragmentTransaction.TRANSIT_FRAGMENT_FADE)
.addToBackStack(null).commit()
}
private fun putImgToBytearray(): ByteArray {
val stream = ByteArrayOutputStream()
val drawable = this.imgThumb!!.drawable as BitmapDrawable
val bitmap = drawable.bitmap
bitmap.compress(Bitmap.CompressFormat.JPEG, 70, stream)
return stream.toByteArray()
}
private fun initMap(view: View, savedInstanceState: Bundle?) {
MapsInitializer.initialize(this.activity)
mMapView = view.findViewById(R.id.mapView)
mMapView!!.onCreate(savedInstanceState)
mMapView!!.onResume() //without this, map showed but was empty
mMapView!!.getMapAsync(this)
}
override fun onMapClick(latLan: LatLng) {
this.map!!.addMarker(MarkerOptions().position(latLan).title("Marker"))
}
/**
* Open a camera activity with the picture returned as a result to onActivityResult
*/
fun openCamera() {
try {
val imageFile = createImageFile()
val callCameraIntent = Intent(MediaStore.ACTION_IMAGE_CAPTURE)
if(callCameraIntent.resolveActivity(activity.packageManager) != null) {
val authorities = activity.packageName + ".fileprovider"
this.imageUri = FileProvider.getUriForFile(context, authorities, imageFile)
callCameraIntent.putExtra(MediaStore.EXTRA_OUTPUT, imageUri)
startActivityForResult(callCameraIntent, IMAGE_PICK_CODE)
}
} catch (e: IOException) {
Toast.makeText(context, "Could not create file!", Toast.LENGTH_SHORT).show()
}
}
/**
* take a picture but check for camera permissions first
*/
fun takePicture() {
val permissionGranted = ActivityCompat.checkSelfPermission(activity, Manifest.permission.CAMERA) == PackageManager.PERMISSION_GRANTED
if (permissionGranted) {
openCamera()
} else {
ActivityCompat.requestPermissions(activity, arrayOf(Manifest.permission.CAMERA), CAMERA_PERMISSION_CODE)
}
}
private fun checkPermissionForImage() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
if ((checkSelfPermission(this.context, Manifest.permission.READ_EXTERNAL_STORAGE) == PackageManager.PERMISSION_DENIED)
&& (checkSelfPermission(this.context, Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_DENIED)
) {
val permission = arrayOf(Manifest.permission.READ_EXTERNAL_STORAGE)
val permissionCoarse = arrayOf(Manifest.permission.WRITE_EXTERNAL_STORAGE)
requestPermissions(permission, PERMISSION_CODE_READ) // GIVE AN INTEGER VALUE FOR PERMISSION_CODE_READ LIKE 1001
requestPermissions(permissionCoarse, PERMISSION_CODE_WRITE) // GIVE AN INTEGER VALUE FOR PERMISSION_CODE_WRITE LIKE 1002
} else {
pickImageFromGallery()
}
}
}
private fun pickImageFromGallery() {
val intent = Intent(Intent.ACTION_PICK)
intent.type = "image/*"
startActivityForResult(intent, IMAGE_PICK_CODE ) // GIVE AN INTEGER VALUE FOR IMAGE_PICK_CODE LIKE 1000
}
/**
* Open the camera after obtaining the permission
*/
override fun onRequestPermissionsResult(requestCode: Int, permissions: Array<String>, grantResults: IntArray) {
when (requestCode) {
CAMERA_PERMISSION_CODE -> {
if (grantResults.isEmpty() || grantResults[0] != PackageManager.PERMISSION_GRANTED) {
Log.i("CAMERA", "Permission has been denied by user")
} else {
openCamera()
Log.i("CAMERA", "Permission has been granted by user")
}
}
}
}
/**
* Save the picture to the thumbnail after taking it
*/
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
if (this.imageUri != imageUri && requestCode == IMAGE_PICK_CODE && resultCode == RESULT_OK) {
try {
pickImageFromGallery()
//Getting the Bitmap from Gallery
val bitmap = MediaStore.Images.Media.getBitmap(context.contentResolver, this.imageUri) as Bitmap
this.imgThumb!!.setImageBitmap(bitmap)
this.pictureTaken = true
} catch (e:IOException) {
e.printStackTrace()
}
} else {
Toast.makeText(context, "Error loading image", Toast.LENGTH_LONG)
}
}
@Throws(IOException::class)
fun createImageFile(): File {
val timeStamp: String = SimpleDateFormat("yyyyMMdd_HHmmss").format(Date())
val imageFileName: String = "JPEG_" + timeStamp + "_"
val storageDir: File = activity.getExternalFilesDir(Environment.DIRECTORY_PICTURES)
if(!storageDir.exists()) storageDir.mkdirs()
val imageFile = File.createTempFile(imageFileName, ".jpg", storageDir)
imageFilePath = imageFile.absolutePath
return imageFile
}
/**
* update the the coordinated of the map center when moving the map
*/
override fun onCameraIdle() {
this.midLatLng = this.map!!.cameraPosition.target
}
override fun onMapReady(googleMap: GoogleMap?) {
this.map = googleMap
this.map!!.setOnCameraIdleListener(this)
this.map!!.setOnMapClickListener(this)
if (this.lat != null) {
this.map!!.moveCamera(CameraUpdateFactory.newLatLngZoom(LatLng(this.lat!!, this.lng!!), 8f))
} else if(this.currentLocation != null) { // TODO
this.map!!.moveCamera(CameraUpdateFactory.newLatLngZoom(this.currentLocation, 8f))
} else {
this.map!!.moveCamera(CameraUpdateFactory.newLatLngZoom(Utils.vienna, 8f)) // Vienna
}
}
override fun onViewCreated(view: View?, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
}
override fun onResume() {
super.onResume()
mMapView!!.onResume()
}
override fun onStart() {
super.onStart()
mMapView!!.onStart()
}
override fun onPause() {
super.onPause()
mMapView!!.onPause()
}
override fun onDestroy() {
super.onDestroy()
mMapView!!.onDestroy()
}
override fun onLowMemory() {
super.onLowMemory();
mMapView!!.onLowMemory();
}
override fun onSaveInstanceState(outState: Bundle) {
super.onSaveInstanceState(outState)
mMapView!!.onSaveInstanceState(outState)
}
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
}
override fun onDetach() {
super.onDetach()
}
}// Required empty public constructor
最佳答案
这是一个空指针异常。 imageUri 为空
MediaStore.Images.Media.getBitmap(context.contentResolver, this.imageUri) as Bitmap
如果你检查 getBitmap() 的实现。
参见
public static final Bitmap getBitmap(ContentResolver cr, Uri url)
throws FileNotFoundException, IOException {
InputStream input = cr.openInputStream(url);
Bitmap bitmap = BitmapFactory.decodeStream(input);
input.close();
return bitmap;
}
你会发现它调用了 openInputStream() ,它需要一个非空的 uri。
public final @Nullable InputStream openInputStream(@NonNull Uri uri)
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
if (this.imageUri != null && requestCode == IMAGE_PICK_CODE && resultCode == RESULT_OK) {
try {
//Getting the Bitmap from Gallery
val bitmap = MediaStore.Images.Media.getBitmap(context.contentResolver, this.imageUri) as Bitmap
this.imgThumb!!.setImageBitmap(bitmap)
this.pictureTaken = true
} catch (e:IOException) {
e.printStackTrace()
}
} else {
Toast.makeText(context, "Error loading image", Toast.LENGTH_LONG)
}
}
关于java - 从图库中选择的图像出现 Kotlin 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55944238/
我的应用程序从一个有 5 个选项卡的选项卡栏 Controller 开始。一开始,第一个出现了它的名字,但其他四个没有名字,直到我点击它们。然后根据用户使用的语言显示名称。如何在选项卡栏出现之前设置选
我有嵌套数组 json 对象(第 1 层、第 2 层和第 3 层)。我的问题是数据表没有出现。任何相关的 CDN 均已导入。该表仅显示部分。我引用了很多网站,但都没有解决我的问题。 之前我使用标准表来
我正在尝试设置要显示的 Parse PFLoginViewController。这是我的一个 View Controller 的类。 import UIKit import Parse import
我遇到了这个问题,我绘制的对象没有出现在 GUI 中。我知道它正在被处理,因为数据被推送到日志文件。但是,图形没有出现。 这是我的一些代码: public static void main(Strin
我有一个树状图,其中包含出现这样的词...... TreeMap occurrence = new TreeMap (); 字符串 = 单词 整数 = 出现次数。 我如何获得最大出现次数 - 整数,
因此,我提示用户输入变量。如果变量小于 0 且大于 10。如果用户输入 10,我想要求用户再次输入数字。我问时间的时候输入4,它说你输入错误。但在第二次尝试时效果很好。例如:如果我输入 25,它会打印
我已经用 css overflow 属性做了一个例子。在这个例子中我遇到了一个溢出滚动的问题。滚动条出现了,但没有工作意味着每当将光标移动到滚动条时,在这个滚动条不活动的时间。我对此一无所知,所以请帮
我现在正在做一个元素。当您单击一个元素时,会出现以下信息,我想知道如何在您单击下一个元素而不重新单击同一元素时使其消失....例如,我的元素中有披萨,我想单击肉披萨看到浇头然后点击奶酪披萨看到浇头和肉
我有一个路由器模块,它将主题与正则表达式进行比较,并将出现的事件与一致的键掩码链接起来。 (它是一个简单的 url 路由过滤,如 symfony http://symfony.com/doc/curr
这个问题在这里已经有了答案: 9年前关闭。 Possible Duplicate: mysql_fetch_array() expects parameter 1 to be resource, bo
我在底部有一个带有工具栏的 View ,我正在使用 NavigationLink 导航到该 View 。但是当 View 出现时,工具栏显示得有点太低了。大约半秒钟后,它突然跳到位。它只会在应用程序启
我试图在我的应用程序上为背景音乐添加一个 AVAudioPlayer,我正在主屏幕上启动播放器,尝试在应用程序打开时开始播放但出现意外行为... 它播放并立即不断创建新玩家并播放这些玩家,因此同时播放
这是获取一个数字,获取其阶乘并将其加倍,但是由于基本情况,如果您输入 0,它会给出 2 作为答案,因此为了绕过它,我使用了 if 语句,但收到错误输入“if”时解析错误。如果你们能提供帮助,我真的很感
暂停期间抛出异常 android.os.DeadObjectException 在 android.os.BinderProxy.transactNative( native 方法) 在 androi
我已经为猜词游戏编写了一些代码。它从用户输入中读取字符并在单词中搜索该字符;根据字符是否在单词中,程序返回并控制一些变量。 代码如下: import java.util.Random; import
我是自动化领域的新手。这是我的简单 TestNG 登录代码,当我以 TestNG 身份运行该代码时,它会出现 java.lang.NullPointerException,双击它会突出显示我导航到 U
我是c#程序员,我习惯了c#的封装语法和其他东西。但是现在,由于某些原因,我应该用java写一些东西,我现在正在练习java一天!我要创建一个为我自己创建一个虚拟项目,以便让自己更熟悉 Java 的
我正在使用 Intellij,我的源类是 main.com.coding,我的资源文件是 main.com.testing。我将 spring.xml 文件放入资源文件中。 我的测试类位于 test.
我想要我的tests folder separate到我的应用程序代码。我的项目结构是这样的 myproject/ myproject/ myproject.py moduleon
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 6 年前。 因此,我尝试比较 2 个值,一个
我是一名优秀的程序员,十分优秀!