當前位置: 首頁>>代碼示例>>Java>>正文


Java CheckBox.setText方法代碼示例

本文整理匯總了Java中android.widget.CheckBox.setText方法的典型用法代碼示例。如果您正苦於以下問題:Java CheckBox.setText方法的具體用法?Java CheckBox.setText怎麽用?Java CheckBox.setText使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在android.widget.CheckBox的用法示例。


在下文中一共展示了CheckBox.setText方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getCheckStatus

import android.widget.CheckBox; //導入方法依賴的package包/類
private void getCheckStatus(View view, final int position) {
    CheckBox checkBox = (CheckBox) view.findViewById(R.id.checkbox);
    checkBox.setText(list.get(position));
    checkBox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
        @Override
        public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
            if (buttonView.isChecked()) {
                checkStatus.set(position, true);
            }
            else {
                checkStatus.set(position, false);
            }
        }
    });
    checkBox.setChecked(checkStatus.get(position));
}
 
開發者ID:Akari10032,項目名稱:12306_Android,代碼行數:17,代碼來源:Date2Adapter.java

示例2: getChildView

import android.widget.CheckBox; //導入方法依賴的package包/類
@Override
public View getChildView(int groupPosition, int childPosition, boolean isLastChild,
    View convertView, ViewGroup parent) {
  if (convertView == null) {
    convertView = inflater.inflate(R.layout.test_loop_item, parent, false);
  }
  CheckBox checkBox = (CheckBox) convertView;
  if (childPosition == 0) {
    boolean allSelected = checkedScenarios.containsAll(getGroup(groupPosition).getLoops());
    checkBox.setChecked(allSelected);
    if (allSelected) {
      checkBox.setText(R.string.unselect_all);
    } else {
      checkBox.setText(R.string.select_all);
    }
  } else {
    Integer item = getChild(groupPosition, childPosition - 1);
    checkBox.setText(String.valueOf(item));
    checkBox.setChecked(checkedScenarios.contains(item));
  }
  return convertView;
}
 
開發者ID:googlesamples,項目名稱:testloopmanager,代碼行數:23,代碼來源:TestLoopGroupAdapter.java

示例3: addItemTrainCategories

import android.widget.CheckBox; //導入方法依賴的package包/類
public ItemBuilder addItemTrainCategories(Context context) {
    view = inflater.inflate(R.layout.item_element_categories_checkboxes, parent, false);
    TextView      tv            = (TextView) view.findViewById(R.id.tv_title);
    TextView      tv2           = (TextView) view.findViewById(R.id.tv_subtitle);
    FlexboxLayout fblCategories = (FlexboxLayout) view.findViewById(R.id.fbl_categories);
    tv.setText("Categorie di treni incluse nella ricerca");
    tv2.setText(SettingsPreferences.getCategoriesAsString(context, " / "));
    for (ENUM_CATEGORIES cat : ENUM_CATEGORIES.values()) {
        CheckBox                   cbCat  = new CheckBox(context);
        FlexboxLayout.LayoutParams params = new FlexboxLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
        params.flexBasisPercent = 0.5f;
        cbCat.setLayoutParams(params);
        cbCat.setText(cat.getAlias());
        cbCat.setChecked(SettingsPreferences.isCategoryEnabled(context, cat));
        cbCat.setOnCheckedChangeListener((buttonView, isChecked) -> {
            if (isChecked || (!isChecked && SettingsPreferences.isPossibleToDisableCheckbox(context))) {
                SettingsPreferences.setCategory(context, cat.name(), isChecked);
                tv2.setText(SettingsPreferences.getCategoriesAsString(context, " / "));
            } else {
                cbCat.setChecked(true);
            }
        });
        fblCategories.addView(cbCat);
    }
    return this;
}
 
開發者ID:albertogiunta,項目名稱:justintrain-client-android,代碼行數:27,代碼來源:ItemBuilder.java

示例4: onCreateContentView

import android.widget.CheckBox; //導入方法依賴的package包/類
@Override
public View onCreateContentView(Bundle savedInstanceState) {
    // inflate and set your custom view here

    View view = inflate(R.layout.simpledialogfragment_check_box);
    mCheckBox = (CheckBox) view.findViewById(R.id.checkBox);

    mCheckBox.setText(getArgString(CHECKBOX_LABEL));

    if (savedInstanceState != null){
        mCheckBox.setChecked(savedInstanceState.getBoolean(CHECKED, false));
    } else {
        mCheckBox.setChecked(getArguments().getBoolean(CHECKED, false));
    }

    mCheckBox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
        @Override
        public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
            setPositiveButtonEnabled(canGoAhead());
        }
    });

    return view;
}
 
開發者ID:eltos,項目名稱:SimpleDialogFragments,代碼行數:25,代碼來源:SimpleCheckDialog.java

示例5: addCheckBoxes

import android.widget.CheckBox; //導入方法依賴的package包/類
protected void addCheckBoxes() {
    llContainer = (LinearLayout) findViewById(R.id.ll_container);
    for(String name : NAMES) {
        CheckBox cb = new CheckBox(this);
        cb.setText(name);
        llContainer.addView(cb);
    }
}
 
開發者ID:rome753,項目名稱:ActivityTaskView,代碼行數:9,代碼來源:BaseActivity.java

示例6: onCreate

import android.widget.CheckBox; //導入方法依賴的package包/類
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    Button deleteTargetFile = new Button(this);
    deleteTargetFile.setText(R.string.button_delete_target_file);
    deleteTargetFile.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            clearOutputs();
            if (lastResponseHandler != null) {
                File toBeDeleted = lastResponseHandler.getTargetFile();
                debugResponse(LOG_TAG, String.format("File was deleted? %b", toBeDeleted.delete()));
                debugResponse(LOG_TAG, String.format("Delete file path: %s", toBeDeleted.getAbsolutePath()));
            } else {
                debugThrowable(LOG_TAG, new Error("You have to Run example first"));
            }
        }
    });
    cbAppend = new CheckBox(this);
    cbAppend.setText("Constructor \"append\" is true?");
    cbAppend.setChecked(false);
    cbRename = new CheckBox(this);
    cbRename.setText("Constructor \"renameTargetFileIfExists\" is true?");
    cbRename.setChecked(true);
    customFieldsLayout.addView(deleteTargetFile);
    customFieldsLayout.addView(cbAppend);
    customFieldsLayout.addView(cbRename);
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:29,代碼來源:DirectorySample.java

示例7: init

import android.widget.CheckBox; //導入方法依賴的package包/類
@Override
protected void init() {
    super.init();
    btn_submit.setText("查看變量");
    editText=new EditText(getActivity());
    checkBox=new CheckBox(getActivity());
    checkBox.setText("是否為男性");
    container.addView(checkBox);
    container.addView(editText);
    //創建實例
    SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(getActivity());
    RxSharedPreferences rxPreferences = RxSharedPreferences.create(preferences);

    //創建個人
    pre_username = rxPreferences.getString("username");
    pre_sex= rxPreferences.getBoolean("sex", true);

    //綁定
    RxCompoundButton.checkedChanges(checkBox)
            .subscribe(pre_sex.asAction());

    RxTextView.textChanges(editText)
            .flatMap(new Func1<CharSequence, Observable<String>>() {
                @Override
                public Observable<String> call(final CharSequence charSequence) {
                    return Observable.create(new Observable.OnSubscribe<String>() {
                        @Override
                        public void call(Subscriber<? super String> subscriber) {
                            subscriber.onNext(charSequence.toString());
                            subscriber.onCompleted();
                        }
                    });
                }
            })
        .subscribe(pre_username.asAction());
}
 
開發者ID:Aiushtha,項目名稱:Go-RxJava,代碼行數:37,代碼來源:RxPreferences_Demo.java

示例8: onCreate

import android.widget.CheckBox; //導入方法依賴的package包/類
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_report_detail);

    mActivityRecord = (ActivityRecord) getIntent().getSerializableExtra("activity_record");

    if (mActivityRecord == null) {
        finish();
        return;
    }

    ((TextView) findViewById(R.id.time)).setText(Utils.DATE_FORMAT.format(new Date(mActivityRecord.when)));
    String title = getString(R.string.record_cost, mActivityRecord.cost, mActivityRecord.activity_name);
    SpannableString ss = new SpannableString(title);
    ForegroundColorSpan colorSpan = new ForegroundColorSpan(mActivityRecord.cost >= StallBuster.getInstance().getThreshold() ? Constants.COLOR_WARNING : Constants.COLOR_NORMAL);
    ss.setSpan(colorSpan, 0, title.indexOf(" "), Spanned.SPAN_INCLUSIVE_INCLUSIVE);
    ((TextView) findViewById(R.id.title)).setText(ss);
    mFilterCb = (CheckBox) findViewById(R.id.filter);
    mFilterCb.setText(getString(R.string.cb_hide_system_callbacks_executed_less_than_some_ms, StallBuster.getInstance().getCallbackThreshold()));
    mFilterCb.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
        @Override
        public void onCheckedChanged(CompoundButton compoundButton, boolean b) {
            mAdapter.setData(filteredRecords());
        }
    });

    mAdapter = new ReportDetailAdapter();
    RecyclerView container = (RecyclerView) findViewById(R.id.container);
    LinearLayoutManager lm = new LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false);
    container.setLayoutManager(lm);
    container.addItemDecoration(new SimpleDecoration());
    mAdapter.setData(filteredRecords());
    container.setAdapter(mAdapter);
}
 
開發者ID:zhangjianli,項目名稱:StallBuster,代碼行數:36,代碼來源:ReportDetailActivity.java

示例9: setMultiSelectItems

import android.widget.CheckBox; //導入方法依賴的package包/類
public void setMultiSelectItems(String[] multiSelectItems, boolean[] selectedItems, final OnMultiChoiceClickListener onMultiChoiceClickListener) {
    if (multiSelectItems != null && multiSelectItems.length > 0) {
        if (selectedItems.length != multiSelectItems.length) {
            throw new IllegalArgumentException("multi select items and boolean array size not equal");
        }
        selectableItemsContainer.removeAllViews();
        selectableItemsContainer.setVisibility(View.VISIBLE);
        for (int i = 0; i < multiSelectItems.length; i++) {
            String item = multiSelectItems[i];
            View view = getLayoutInflater().inflate(R.layout.cfdialog_multi_select_item_layout, null);
            CheckBox checkBox = (CheckBox) view.findViewById(R.id.cfdialog_multi_select_item_checkbox);
            checkBox.setText(item);
            checkBox.setChecked(selectedItems[i]);
            final int position = i;
            checkBox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
                @Override
                public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                    if (onMultiChoiceClickListener != null) {
                        onMultiChoiceClickListener.onClick(CFAlertDialog.this, position, isChecked);
                    }
                }
            });
            selectableItemsContainer.addView(view);
        }
    } else {
        selectableItemsContainer.setVisibility(View.GONE);
    }
}
 
開發者ID:Codigami,項目名稱:CFAlertDialog,代碼行數:29,代碼來源:CFAlertDialog.java

示例10: setUpView

import android.widget.CheckBox; //導入方法依賴的package包/類
@Override
protected void setUpView(View view, Context context, Bundle savedInstanceState,
                         final SimpleFormDialog.DialogActions actions,
                         boolean isLastElement, boolean isOnlyElement) {

    checkBox = (CheckBox) view.findViewById(R.id.checkBox);

    // Label
    checkBox.setText(field.getText(context));

    // Check preset
    if (savedInstanceState != null) {
        checkBox.setChecked(savedInstanceState.getBoolean(SAVED_CHECK_STATE));
    } else {
        checkBox.setChecked(field.getInitialState(context));
    }

    // Positive button state for single element forms
    if (isOnlyElement) {
        checkBox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
            @Override
            public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                actions.updatePosButtonState();
            }
        });
    }

}
 
開發者ID:eltos,項目名稱:SimpleDialogFragments,代碼行數:29,代碼來源:CheckViewHolder.java

示例11: onCreate

import android.widget.CheckBox; //導入方法依賴的package包/類
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_symptoms);

    //Programmatically set style due to dynamic layout/instantiation of symptom checkboxes
    final LinearLayout sensationsLayout = (LinearLayout) findViewById(R.id.sensations);
    final LinearLayout colorsLayout = (LinearLayout) findViewById(R.id.colors);
    final LinearLayout othersLayout = (LinearLayout) findViewById(R.id.others);
    LinearLayout[] layouts = {sensationsLayout, colorsLayout, othersLayout};

    final Button finish = (Button) findViewById(R.id.btnDone);
    finish.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            setResult();
        }
    });

    for (int z = 0; z < 9; z++)
    {
        conditionIndex.add(z);
    }

    //set onclick listener for every box to disable/enable other possible symptoms
    for (int i = 0; i < checkboxes.length; i++)
    {
        for (int j = 0; j < checkboxes[i].length; j++)
        {
            cb = new CheckBox(this);
            cb.setText(strings[i][j]);
            cb.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {

                @Override
                public void onCheckedChanged(final CompoundButton buttonView, final boolean isChecked) {
                    String str = buttonView.getText().toString();
                    // TODO Auto-generated method stub
                    if (isChecked) {
                        current.add(str);
                        counter++;
                    } else {
                        current.remove(str);
                        counter--;
                    }
                    update();
                }
            });
            checkboxes[i][j] = cb;
            layouts[i].addView(checkboxes[i][j]);
        }
    }
}
 
開發者ID:smajko,項目名稱:what_are_those_app,代碼行數:53,代碼來源:SymptomScreen.java

示例12: onAddEditTextToDialogView

import android.widget.CheckBox; //導入方法依賴的package包/類
@Override
protected void onAddEditTextToDialogView(View dialogView, final EditText editText) {
    super.onAddEditTextToDialogView(dialogView, editText);
    final ViewGroup container = (ViewGroup) editText.getParent();
    if (container != null) {
        final CheckBox cb = new CheckBox(getContext());
        cb.setText(R.string.discoverHttps);
        cb.setChecked(true);

        final Button b = new Button(getContext());
        b.setText(R.string.discoverServer);

        container.addView(b, ViewGroup.LayoutParams.MATCH_PARENT,
                ViewGroup.LayoutParams.WRAP_CONTENT);
        container.addView(cb, ViewGroup.LayoutParams.WRAP_CONTENT,
                ViewGroup.LayoutParams.WRAP_CONTENT);

        final ProgressBar p = new ProgressBar(getContext());

        b.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                b.setEnabled(false);
                ((AlertDialog) getDialog()).getButton(AlertDialog.BUTTON_POSITIVE).setEnabled(false);
                ((AlertDialog) getDialog()).getButton(AlertDialog.BUTTON_NEGATIVE).setEnabled(false);

                AsyncTask discoveryTask = new AsyncTask() {
                    @Override
                    protected Object doInBackground(Object[] objects) {
                        ServerDiscovery mDiscovery = new ServerDiscovery((NsdManager) getContext().getSystemService(Context.NSD_SERVICE));
                        mDiscovery.discover(new ServerDiscovery.DiscoveryListener() {
                            @Override
                            public void found(final String serverUrl) {
                                b.post(new Runnable() {
                                    @Override
                                    public void run() {
                                        editText.setText(serverUrl);
                                    }
                                });
                            }

                            @Override
                            public void notFound() {
                                b.post(new Runnable() {
                                    @Override
                                    public void run() {
                                        Toast.makeText(getContext(), getContext().getString(R.string.serverNotFound), Toast.LENGTH_LONG).show();
                                    }
                                });
                            }
                        }, !cb.isChecked(), cb.isChecked());

                        return null;
                    }

                    @Override
                    protected void onPostExecute(Object o) {
                        b.setEnabled(true);
                        ((AlertDialog) getDialog()).getButton(AlertDialog.BUTTON_POSITIVE).setEnabled(true);
                        ((AlertDialog) getDialog()).getButton(AlertDialog.BUTTON_NEGATIVE).setEnabled(true);
                    }
                };
                discoveryTask.execute();
            }
        });

    }

}
 
開發者ID:vbier,項目名稱:habpanelviewer,代碼行數:70,代碼來源:ServerPreference.java

示例13: initViews

import android.widget.CheckBox; //導入方法依賴的package包/類
private void initViews() {
	TextView tvTitle = (TextView)findViewById(R.id.customDlg_tvTitle);
	TextView tvSeparator0 = (TextView)findViewById(R.id.customDialog_tvSeparator0);
	TextView tvInfo = (TextView)findViewById(R.id.customDlg_tvInfo);
	chkNoRepeat = (CheckBox)findViewById(R.id.customDialog_chkNoRepeat);
	TextView tvSeparator1 = (TextView)findViewById(R.id.customDialog_tvSeparator1);
	LinearLayout llytButtons = (LinearLayout)findViewById(R.id.customDialog_llytButtons);
	btnPositive = (Button)findViewById(R.id.customDlg_btnPositive);
	btnPositive.setOnClickListener(this);
	TextView tvSeparator2 = (TextView)findViewById(R.id.customDialog_tvSeparator2);
	btnNatural = (Button)findViewById(R.id.customDlg_btnNatural);
	btnNatural.setOnClickListener(this);
	TextView tvSeparator3 = (TextView)findViewById(R.id.customDialog_tvSeparator3);
	btnNagative = (Button)findViewById(R.id.customDlg_btnNagative);
	btnNagative.setOnClickListener(this);
	
	setCancelable(cancelable);
	if (isEmpty(csTitle)){
		setGone(tvTitle);
		setGone(tvSeparator0);
	}else{
		tvTitle.setText(csTitle);
	}
	tvInfo.setText(csMessage);
	if (isEmpty(csCheckBox)){
		setGone(chkNoRepeat);
	}else{
		chkNoRepeat.setChecked(checkable);
		chkNoRepeat.setText(csCheckBox);
	}
	if (isEmpty(csPositive)){
		setGone(tvSeparator1);
		setGone(llytButtons);
	}else{
		btnPositive.setText(csPositive);
	}
	if (isEmpty(csNatural)){
		setGone(tvSeparator2);
		setGone(btnNatural);
	}else{
		btnNatural.setText(csNatural);
	}
	if (isEmpty(csNagative)){
		setGone(tvSeparator3);
		setGone(btnNagative);
	}else{
		btnNagative.setText(csNagative);
	}
}
 
開發者ID:SShineTeam,項目名稱:Huochexing12306,代碼行數:50,代碼來源:CustomDialog.java

示例14: getItemView

import android.widget.CheckBox; //導入方法依賴的package包/類
public View getItemView(int position, View convertView, ViewHolder holder) {
    CircleImageView iv_avatar = (CircleImageView) holder.getView(R.id.iv_avatar);
    TextView tv_username = (TextView) holder.getView(R.id.tv_username);
    TextView tv_date = (TextView) holder.getView(R.id.tv_date);
    TextView tv_content = (TextView) holder.getView(R.id.tv_content);
    CheckBox cb_fav = (CheckBox) holder.getView(R.id.cb_fav);
    TextView tv_comment = (TextView) holder.getView(R.id.tv_comment);
    TextView tv_share = (TextView) holder.getView(R.id.tv_share);
    ImageView iv_tag = (ImageView) holder.getView(R.id.iv_tag);
    ImageView iv_avatar_tag = (ImageView) holder.getView(R.id.iv_avatar_tag);
    ProgressBar pb_active = (ProgressBar) holder.getView(R.id.pb_active);
    TextView tv_del = (TextView) holder.getView(R.id.tv_del);
    NineGridLayout nineGridLayout = (NineGridLayout) holder.getView(R.id.iv_content);
    final int i = position;
    ((Button) holder.getView(R.id.btn_menu)).setOnClickListener(new OnClickListener() {
        public void onClick(View v) {
            TimeLineAdapter.this.showPopupMenu(v, i);
        }
    });
    Post post = (Post) this.data.get(position);
    tv_username.setText(post.user != null ? post.user.nickname : "");
    tv_date.setText(DateHelper.timezoneFormat(post.created_at, "MM-dd HH:mm"));
    tv_content.setText(post.body);
    TimeLineUtility.addLinks(tv_content);
    loadAvatar(iv_avatar, post);
    loadContentImg(nineGridLayout, post);
    cb_fav.setText(post.envious_count + "");
    tv_comment.setText(post.comment_count + "");
    cb_fav.setChecked(isFav(post));
    setUpTopTag(iv_tag, post);
    setUpAvatarTag(pb_active, iv_avatar_tag, post);
    setUpOwner(tv_del, post);
    AvartaClickListener listener = new AvartaClickListener(post.user.nickname);
    iv_avatar.setOnClickListener(listener);
    tv_username.setOnClickListener(listener);
    cb_fav.setOnClickListener(new FavClickListener(position));
    tv_comment.setOnClickListener(new CommentClickListener(post, position));
    tv_share.setOnClickListener(new ShareClickListener(post));
    convertView.setOnLongClickListener(new LongClickCopy(post));
    return convertView;
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:42,代碼來源:TimeLineAdapter.java

示例15: barcodeResult

import android.widget.CheckBox; //導入方法依賴的package包/類
@Override
public void barcodeResult(BarcodeResult result) {
    if(result.getText() == null) {
        return;
    }

    byte[] rawBytes = new byte[0];
    try {
        rawBytes = result.getText().getBytes("ISO-8859-1");
    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    }

    if (splittedFile.isPartAdded(rawBytes)) {
        Toast.makeText(context, "Ignored: " + String.valueOf(rawBytes[0]), Toast.LENGTH_SHORT).show();
        return;
    }

    QRCode qrCode = splittedFile.addPart(rawBytes);

    if (splittedFile.isCompleted()) {
        Intent intent = new Intent(getBaseContext(), SaveActivity.class);
        intent.putExtra("MERGED_FILE", splittedFile.getMergedFile());
        intent.putExtra("FILENAME", splittedFile.getFilename());
        startActivity(intent);
        finish();
    }

    if (checkBoxes.size() == 0) {
        LinearLayout progress = (LinearLayout) findViewById(R.id.progress);
        for (int i = 0; i < splittedFile.getPiecesQuantity(); i++) {
            CheckBox checkBox = new CheckBox(context);
            checkBox.setText(String.format(Locale.getDefault(), "%d", i + 1));
            checkBox.setClickable(false);
            progress.addView(checkBox);
            checkBoxes.add(checkBox);
        }
        TextView first_scan_text = (TextView) findViewById(R.id.first_scan_text);
        first_scan_text.setVisibility(View.GONE);
    }

    checkBoxes.get(qrCode.getMetadata().getNumber() - 1).setChecked(true);
}
 
開發者ID:cgimenes,項目名稱:binqr-mobile,代碼行數:44,代碼來源:ScanActivity.java


注:本文中的android.widget.CheckBox.setText方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。