Так что, если вы настроите правильные параметры, вы будете хороши, но я все равно рекомендую извлечь его для простоты обновления до заводской настройки, как это.

у поделиться текстом в моемCardView используя общий доступ, используя kotlin, но есть проблема с последней строкой в ​​коде, в kotlin код

 val shareIntent = Intent()
            shareIntent.action = Intent.ACTION_SEND
            shareIntent.putExtra(Intent.EXTRA_STREAM, "ali")
            shareIntent.type = "text/plain"
            startActivity(Intent.createChooser(shareIntent, getResources().getText(R.string.send_to)))

вот проблема в коде

startActivity(Intent.createChooser(shareIntent, getResources().getText(R.string.send_to)))

Помогите мне, пожалуйста

увидеть изображения, чтобы понять меня

картинки

https://ibb.co/jQwYXw

https://ibb.co/id0tXw

https://ibb.co/fbCU5G

полный код адаптера

class MyAdapter(context: Context, listItem: ArrayList<com.EliteTeam.comedytaste.Model.Movie>) : RecyclerView.Adapter<MyAdapter.MyViewHolder>() {

var Context = context
var movieList = listItem;
var layoutInflator = LayoutInflater.from(context)

override fun onCreateViewHolder(parent: ViewGroup?, viewType: Int): MyViewHolder {

    var inflateView = layoutInflator.inflate(R.layout.single_item, parent, false)

    return MyViewHolder(inflateView)
}

override fun onBindViewHolder(holder: MyViewHolder?, position: Int) {

    holder?.moviewTitle?.text = movieList[position].name
    holder?.movieDescription!!.text=   movieList[position].description
    //holder!!.cardImageView!!.background=   movieList[position].image

    holder?.onclick(Context, position)
    holder!!.cardImageView.setBackgroundResource(movieList[position].image)
}

override fun getItemCount(): Int {

    return movieList.size
}

class MyViewHolder(itemView: View?) : RecyclerView.ViewHolder(itemView) {

    var moviewTitle: TextView = itemView?.findViewById(R.id.movieTitleTextView)!!
    var movieDescription: TextView = itemView!!.findViewById(R.id.movieDescriptionTextView)
    var cardImageView: CardView = itemView!!.findViewById(R.id.imageCard)
    var share: ImageButton = itemView!!.findViewById(R.id.share)

    fun onclick(context: Context, position: Int) {
        cardImageView.setOnClickListener {

    }

       share.setOnClickListener {

           val shareIntent = Intent()
         shareIntent.action = Intent.ACTION_SEND
           shareIntent.putExtra(Intent.EXTRA_TEXT, "ali")
          shareIntent.type = "text/plain"


           startActivity(Intent.createChooser(shareIntent,"send to"))

}} }}
 Ankit Patidar02 дек. 2017 г., 21:06
В чем проблема на самом деле ???
 donfuxx03 дек. 2017 г., 07:34
"Не сработало" .. подробнее пожалуйста
 Ali Alsaadi02 дек. 2017 г., 21:29
этот код работал в Java, прежде чем я перевести его на kotlin, когда я перевел его на kotlin, он не работал

Ответы на вопрос(3)

Решение Вопроса

Попробуйте это: - ИспользуйтеIntent.EXTRA_STREAM только когда вам нужно отправить двоичные данные, такие как изображения, если вы хотите отправить текстовое использованиеIntent.EXTRA_TEXT

    val shareIntent = Intent()
    shareIntent.action = Intent.ACTION_SEND
    shareIntent.type="text/plain"
    shareIntent.putExtra(Intent.EXTRA_TEXT, "This is my text to send.");
    startActivity(Intent.createChooser(shareIntent,getString(R.string.send_to)))
 Suraj Nair03 дек. 2017 г., 10:12
Просто замените extra.stream на extra.text в вашем существующем коде, как я объяснил выше
 Suraj Nair03 дек. 2017 г., 10:41
Это помогает?
 Ali Alsaadi03 дек. 2017 г., 10:09
не работает createChooser (shareIntent, getString (R.string.send_to)), но когда добавляется запятая после отправки _to), это говорит мне, чтобы добавить отправителю, какую дозу это означает createChooser (shareIntent, getString (R.string.send_to),)
 Suraj Nair03 дек. 2017 г., 10:11
Я думаю твои пропущенные закрывающие скобки) вместо запятой
 Ali Alsaadi03 дек. 2017 г., 10:47
да, но, как я сказал в первой команде, в котлине отсутствует некий отправитель вызова

конечно, можете перейти к определению Начальной активности и просмотреть перегрузки, поскольку вы не передаете один из приемлемых параметров.

То, что я хотел бы сделать, чтобы иметь повсюду навигационный код, - это создать IntentFactory следующим образом:

public class IntentFactory {

/**
 *
 * @param context
 * @return intent
 */
public static Intent getLoginIntent(Context context, boolean launchedFromNotification, boolean isApproveNotify, String idOfDetailToOpen, NewsModel notificationModel){
    Intent intent = new Intent(context, LoginActivity.class);
    intent.putExtra(Globals.INTENT_KEYS.KEY_FROM_BADGE_ACCESS, launchedFromNotification);
    intent.putExtra(Globals.INTENT_KEYS.KEY_ID_OF_DETAIL_TO_OPEN, idOfDetailToOpen);
    intent.putExtra(Globals.INTENT_KEYS.KEY_IS_APPROVE_NOTIFY, isApproveNotify);
    intent.putExtra(Globals.INTENT_KEYS.KEY_ALERT_NOTIFICATION_FOR_APPROVAL, notificationModel);
    intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK|Intent.FLAG_ACTIVITY_CLEAR_TASK);
    return intent;

}
/**
 *
 * @param filePath
 * @param subject
 * @param body
 * @return
 */
public static Intent getSendImageIntent(String filePath, String subject, String body){
    Intent intent = new Intent(Intent.ACTION_SEND);
    intent.setType("image/jpg");
    intent.putExtra(Intent.EXTRA_STREAM, Uri.parse("file://" + filePath));
    intent.putExtra(Intent.EXTRA_SUBJECT, subject);
    intent.putExtra(Intent.EXTRA_TEXT, body);
    return Intent.createChooser(intent, "Share File");

}
/**
 *
 * @param toEmailAddresses
 * @param subject
 * @param body
 * @param uris
 * @return
 */
public static Intent getEmailIntent(String[] toEmailAddresses, String subject, String body, ArrayList<Uri> uris) {
    Intent intent = new Intent(Intent.ACTION_SEND_MULTIPLE);
    intent.setType("text/plain");
    intent.putExtra(Intent.EXTRA_EMAIL, toEmailAddresses);
    intent.putExtra(Intent.EXTRA_SUBJECT, subject);
    intent.putExtra(Intent.EXTRA_TEXT, body);
    intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);

    if(uris != null) {
        intent.putParcelableArrayListExtra(Intent.EXTRA_STREAM, uris);

    }

    return Intent.createChooser(intent, "Send mail...");

}
/**
 * Used to launch to app details screen for toggling of permissions or other things
 * @param context
 * @return
 */
public static Intent getShowAppDetailSettingsIntent(Context context){
    Intent intent = new Intent();
    intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
    intent.addCategory(Intent.CATEGORY_DEFAULT);
    intent.setData(Uri.parse("package:" + context.getPackageName()));
    intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
    intent.addFlags(Intent.FLAG_ACTIVITY_NO_HISTORY);
    intent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS);
    return intent;

}

}

Тогда вы можете легко управлять своими звонками StartActivity с

      String email = SharedPreferencesManager.getInstance(getContext()).getSecuredPreference(REMEMBER_ME_USER_KEY);
    String subject = getString(R.string.message) + " " + model.getFirstName() + " " + model.getLastName();
    String body = getString(R.string.subject) + model.getFirstName() + " " + model.getLastName() + "\n" + model.getShootKeyUrl();

    startActivity(IntentFactory.getEmailIntent(new String[]{email}, subject, body, null));

Так что, если вы настроите правильные параметры, вы будете хороши, но я все равно рекомендую извлечь его для простоты обновления до заводской настройки, как это.

Просто используйте

context.startActivity

Insted of

startActivity
 Ali Alsaadi03 дек. 2017 г., 20:18
да это решение же Suraj Nair в комментарии спасибо

Ваш ответ на вопрос